一、八种基本数据类型
二、分为四大类
1、整型
byte 、short 、int 、long
2、浮点型
float 、 double
3、字符型
char
4、布尔型
boolean
三、数据类型详细介绍
整型(byte、short、int、long)
浮点型(float、double)
float 和 double 都是表示浮点型的数据类型,它们之间的区别在于精确度的不同。
float(单精度浮点型)取值范围:3.402823e+38~1.401298e-45(e+38 表示乘以10的38次方,而e-45 表示乘以10的负45次方)
double(双精度浮点型)取值范围:1.797693e+308~4.9000000e-324(同上)
double 类型比float 类型存储范围更大,精度更高。
带小数点的字面量默认属于double类型,所以声明一个float类型的变量时,都要在数字后面加上 “F” 或 “f”。
在Java中,对浮点型数据使用基本的加减乘除运算符,计算的数据可能不是完全精确的,有时候可能出现小数点后几位浮动。对于金融行业或者和钱有关的业务来说,这是不可接受的,当出现与金钱数值相关的场景,建议使用BigDecimal 进行运算。
字符型(char)
字符型 char 在 Java 语言中占用 2 个字节,char 类型的字面量必须使用半角的单引号括起来,取值范围为[0-65535],char 和 short 都占用 2 个字节,但是 char 可以取到更大的正整数,因为 char 类型没有负数。
注意点:
-
字符型常量需要使用单引号(’ ')括起来,如:char c1 = ‘a’ – char c2 = ‘中’ – char c3 = ‘9’
-
char本质是整数,输出时是unicode码
-
给char赋一个整数,输入会按照unicode码输出
布尔型(boolean)
boolean 型只有两个取值 true 和 false
它的默认值是 false
对于布尔型占用的空间,得看JVM对于它的具体实现,有些JVM底层其实是使用0和1来表示true和false,那么就是4字节。
四、基本数据类型之间的转换
基本数据类型之间是存在固定的转换规则的,现总结出以下 6 条规则,无论是哪个程序,
将这 6 个规则套用进去,问题迎刃而解:
-
八种基本数据类型中,除 boolean 类型不能转换,剩下七种类型之间都可以进行转换;
-
如果整数型字面量没有超出 byte,short,char 的取值范围,可以直接将其赋值给 byte,short,char 类型的变量;
-
小容量向大容量转换称为自动类型转换,容量从小到大的排序为:byte < short(char) < int < long <float
< double,其中 short 和 char 都占用两个字节,但是 char 可以表示更大 的正整数; -
大容量转换成小容量,称为强制类型转换,编写时必须添加“强制类型转换符”,但 运行时可能出现精度损失,谨慎使用;
-
byte,short,char 类型混合运算时,先各自转换成 int 类型再做运算;
-
多种数据类型混合运算,各自先转换成容量最大的那一种再做运算