进制,数据类型,基本类型字面值,基本数据类型运算规则,基本数据类型转化规则

2023-10-13 22:59

本文主要是介绍进制,数据类型,基本类型字面值,基本数据类型运算规则,基本数据类型转化规则,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

进制

计数方式

二进制:0—1;1+1=10  11+1=100 在jdk1.7之前,程序中不允许定义二进制,从jdk1.7之后程序中可以定义二进制数字--以OB/ob作为开头 ob0011 ob101101

八进制0-7 满八进一 7+1=10 17+1=20 77+1=100 要求已0作为开头

十进制 0-9;满十进一,数字如果没有特殊标识,就默认是十进制

十六进制  0-9,a-f,满十六进一8+1=9   9+1=A 39+1=3A  99+1=A0  FF+1=100要求以OX/ox作为开头

1数据类型

扩展:在计算机中是以二进制形式来存储数据,每一位二进制在内存中称之为 位(bit 简写为b),8位=1字节(byte简写为B),1024B=1KB-->MB-->GB-->TB

1.1基本数据类型

1.1.1数值型

整数型

byte字节型     1个字节    27 ~27-1   -128~127

Short 短整型     2个字节  215 ~2151 -32768~32767

Int   整型       4个字节  231 ~231-1

Long 长整型     8个字节  263~263-1   需要在结尾添加L作为表示

自jdk1.7之后可以用_分割

Int a=1_122_123  

浮点型

float    单精度   四个字节    需要在结尾添加f/F作为标识  float a=1.23f -1038~1038

double  双精度   八个字节     默认为double类型      double b=1.256 -10308~10308   double a=4e4  (4*410)  double d=0xsp3表示十六进制的科学计数法 xpy表示x*2y

 

字符型

Char   字符型   两个字节   0-65535  默认编码utf-16  char a=’\u20ac’;

转义字符

制表符‘\t’  回车  ‘\r’  换行‘\n’\--->‘\n’ 单引号 ‘\’’双引号 ‘\”’

扩展:字符在存储过程中需要按照某中规则转化为数字,这种转化称之为编码,记录编码形成的表格形式称之为编码表 -- 码表

IOS-8859-1   西欧码表   1个字节1个字符

Gb2312      国标码      gbk   两个字节一个字符   收录了大部分简体汉字以及一部分繁体汉字

Unicode编码体系  万国码体系  utf-8  三个字节1个字符  utf-16   2个字节1个字符

布尔型
boolean类型两个取值ture和 false

1.2 引用数据类型

接口(interface) 类(class) 数组([ ])

变量定义格式    变量类型 标识符=值;

2标识符命名规则 

  1. 可以使用数字,字母,下划线 $
  2. 不能使用数字开头
  3. 见名知意(驼峰命名法)
  4. 严格区分大小写
  5. 不能使用java关键字

3基本数据类型字面值 

1整型默认是int类型

2小数默认是double类型

3 byte short char三种比int小的整数可以使用范围内的值直接赋值

4字面值后缀 float类型后缀为f double类型后缀为d long类型后缀为l

(后缀不区分大小写)

5字面值前缀 二进制使用0b作为前缀

八进制采用0作为前缀

十进制没有前缀

十六进制采用0x作为前缀

4 基本数据类型转换规则

(除boolean外),此处所说的大小是基本数据类型的取值范围大小:小转大 直接转,大转小 强制转

5基本数据类型运算规则

1相同数据类型运算时结果为同一类型例如3/2=1

2不同数据类型运算时结果为大类型

3 浮点数特殊值,0/0系统报错浮点型除以零时正数除以0则为正无穷大  负数除以0则为负无穷小,0.0/0结果为 NaN not a number

4浮点类型结果不准确

5 当整数运算超过其所在类型的取值范围之后会出现溢出  例如System.out.println(300000000*60*60*24*365); 由于字面值整型默认为int其结果已经超出int取值范围 System.out.println(300000000*60*60*24*365L);也是错误写法,在进行第一次运算的时候其结果已经超过int的取值范围结果也不准确, 正确写法应该是 System.out.println(300000000L*60*60*24*365);

小练习

1 在控制台打印  泡泡今年3岁了月薪99999.99感慨java是世界上最好的语言

代码

运行结果

练习二

在控制台打印除boolean类型外 其他七种基本数据类型的最大值与最小值

/*
本类用来测试几种基本类型的取值范围*/public class TestTypeScope {public static void main(String[] args) {int maxValue = Integer.MAX_VALUE;byte maxValue1 = Byte.MAX_VALUE;short maxValue2 = Short.MAX_VALUE;long maxValue3 = Long.MAX_VALUE;float maxValue4 = Float.MAX_VALUE;double maxValue5 = Double.MAX_VALUE;byte minValue = Byte.MIN_VALUE;short minValue1 = Short.MIN_VALUE;int minValue2 = Integer.MIN_VALUE;long minValue3 = Long.MIN_VALUE;float minValue4 = Float.MIN_VALUE;double minValue5 = Double.MIN_VALUE;char maxValue6 = Character.MAX_VALUE;char minValue6 = Character.MIN_VALUE;/*
boolean 测试布尔类型*/boolean b1=true;//      真为1boolean b2=false;//     假为0//ctrl+alt+向下键快速向下复制一行 如果翻转屏幕 禁用系统快捷键//ctrl+f 查找替换replace AllSystem.out.println("byte最大值为:\t"+maxValue1+"\tbyte的最小值为:\t"+minValue);System.out.println("short最大值为:\t"+maxValue2+"\tshort的最小值为:\t"+minValue1);System.out.println("int最大值为:\t"+maxValue+"\tint的最小值为:\t"+minValue2);System.out.println("long最大值为:\t"+maxValue3+"\tlong的最小值为:\t"+minValue3);System.out.println("float最大值为:\t"+maxValue4+"\tfloat的最小值为:\t"+minValue4);System.out.println("double最大值为:\t"+maxValue5+"\tdouble的最小值为:\t"+minValue5);System.out.println("char最大值为:\t"+maxValue6+"\tchar的最小值为:\t"+minValue6);/*测试字符类型charchar类型可以保存一个数字/字符/汉字  如果存的是数字,会在打印的时候把对应的字符拿出来ASCII表中规定了0-127对应的字符 128-65535以问号处理*/char c1='a';char c2='中';char c3=97;System.out.println(c1);System.out.println(c2);System.out.println(c3);}
}

运行结果

3.

练习值交换
package cn.tude.basic;import java.util.Scanner;
/*
本类用来练习值交换类*/
public class TestValueExchange {/*main方法程序的入口*/public static void main(String[] args) {Scanner scanner=new Scanner(System.in);System.out.println("请输入第一个数字");int a=scanner.nextInt();System.out.println("请输入第二个数字");int b=scanner.nextInt();System.out.println("您输入的第一个数字为"+a);System.out.println("您输入的第二个数字为"+b);//交换过程int temp;temp=a;//用b的值覆盖掉a的值a=b;//用temp覆盖掉b的值b=temp;System.out.println("反转之后第一个数的值为"+a);System.out.println("反转之后第二个数-的值为"+b);//c赋值给tee之后为什么打印c c的值为1//c的值赋值给tee之后c的值c的值不变///* int c=1,tee;tee=c;System.out.println(c);*/}
}

运行结果

这篇关于进制,数据类型,基本类型字面值,基本数据类型运算规则,基本数据类型转化规则的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/206434

相关文章

Python中Json和其他类型相互转换的实现示例

《Python中Json和其他类型相互转换的实现示例》本文介绍了在Python中使用json模块实现json数据与dict、object之间的高效转换,包括loads(),load(),dumps()... 项目中经常会用到json格式转为object对象、dict字典格式等。在此做个记录,方便后续用到该方

Python ORM神器之SQLAlchemy基本使用完全指南

《PythonORM神器之SQLAlchemy基本使用完全指南》SQLAlchemy是Python主流ORM框架,通过对象化方式简化数据库操作,支持多数据库,提供引擎、会话、模型等核心组件,实现事务... 目录一、什么是SQLAlchemy?二、安装SQLAlchemy三、核心概念1. Engine(引擎)

Python异步编程之await与asyncio基本用法详解

《Python异步编程之await与asyncio基本用法详解》在Python中,await和asyncio是异步编程的核心工具,用于高效处理I/O密集型任务(如网络请求、文件读写、数据库操作等),接... 目录一、核心概念二、使用场景三、基本用法1. 定义协程2. 运行协程3. 并发执行多个任务四、关键

python中的显式声明类型参数使用方式

《python中的显式声明类型参数使用方式》文章探讨了Python3.10+版本中类型注解的使用,指出FastAPI官方示例强调显式声明参数类型,通过|操作符替代Union/Optional,可提升代... 目录背景python函数显式声明的类型汇总基本类型集合类型Optional and Union(py

MySQL中查询和展示LONGBLOB类型数据的技巧总结

《MySQL中查询和展示LONGBLOB类型数据的技巧总结》在MySQL中LONGBLOB是一种二进制大对象(BLOB)数据类型,用于存储大量的二进制数据,:本文主要介绍MySQL中查询和展示LO... 目录前言1. 查询 LONGBLOB 数据的大小2. 查询并展示 LONGBLOB 数据2.1 转换为十

Go语言连接MySQL数据库执行基本的增删改查

《Go语言连接MySQL数据库执行基本的增删改查》在后端开发中,MySQL是最常用的关系型数据库之一,本文主要为大家详细介绍了如何使用Go连接MySQL数据库并执行基本的增删改查吧... 目录Go语言连接mysql数据库准备工作安装 MySQL 驱动代码实现运行结果注意事项Go语言执行基本的增删改查准备工作

MyBatis的xml中字符串类型判空与非字符串类型判空处理方式(最新整理)

《MyBatis的xml中字符串类型判空与非字符串类型判空处理方式(最新整理)》本文给大家介绍MyBatis的xml中字符串类型判空与非字符串类型判空处理方式,本文给大家介绍的非常详细,对大家的学习或... 目录完整 Hutool 写法版本对比优化为什么status变成Long?为什么 price 没事?怎

MySQL数据类型与表操作全指南( 从基础到高级实践)

《MySQL数据类型与表操作全指南(从基础到高级实践)》本文详解MySQL数据类型分类(数值、日期/时间、字符串)及表操作(创建、修改、维护),涵盖优化技巧如数据类型选择、备份、分区,强调规范设计与... 目录mysql数据类型详解数值类型日期时间类型字符串类型表操作全解析创建表修改表结构添加列修改列删除列

C#之枚举类型与随机数详解

《C#之枚举类型与随机数详解》文章讲解了枚举类型的定义与使用方法,包括在main外部声明枚举,用于表示游戏状态和周几状态,枚举值默认从0开始递增,也可手动设置初始值以生成随机数... 目录枚举类型1.定义枚举类型(main外)2.使用生成随机数总结枚举类型1.定义枚举类型(main外)enum 类型名字

Python lambda函数(匿名函数)、参数类型与递归全解析

《Pythonlambda函数(匿名函数)、参数类型与递归全解析》本文详解Python中lambda匿名函数、灵活参数类型和递归函数三大进阶特性,分别介绍其定义、应用场景及注意事项,助力编写简洁高效... 目录一、lambda 匿名函数:简洁的单行函数1. lambda 的定义与基本用法2. lambda