JAVA中基本数据类型:
类型: | 字节: | 范围: | 默认值: |
byte | 1 | -128~127 | 0 |
short | 2 | -32768~32767 | 0 |
char | 2 | 0~65535 | 'u0000' |
int | 4 | -2147483648~2147483647 | 0 |
long | 8 | -2^63~2^63-1 | 0L或0l |
float | 4 | 3.402823e38~1.401298e-45 | 0.0F或0.0f |
double | 8 | 1.797693e308~4.9000000e-324 | 0.0D或0.0d |
boolean | 1 | false 或 true | false |
所以,基本数据类型的精度(亦称容量大小)排序为(从小到大):(byte->short->char)->int->long->float->double
向下转换:(强制类型转换)
当精度高的类型转到精度低的类型时叫做向下转换,向下转换需要强制转换,即使用 (类型名) 运算符,可能会导致精度降低或溢出。
向上转换:(隐式类型转换)
当精度低的类型转到精度高的类型时叫做向上转换,向上转换一般直接由编译器完成,当几个基本数据类型参与运算时,计算结果的类型是参与运算中精度最高的那个运算数的类型,其他运算数的类型将被自动转为精度最高的那个运算数的类型。
之所以要给byte,short,char三个类型加上括号,是因为,当它们参与运算时首先会被提升为int类型,也就说明他们之间不会发生隐式类型转换。
另外,boolean类型不会发生类型转换,即(boolean)运算符无意义,并且boolean类型只能被关键字 true 和 false,以及逻辑运算符的结果赋值。
例如:
1 byte a; 2 short b; 3 char c; 4 int d; 5 long e; 6 a = a+a;//错误,a + a的类型为int,因为在计算时,byte类型的a变量被自动提升为int类型 7 a = 'A';//正确,'A'是字符字面量,是一个常量,值为65,在byte范围内 8 a = 12;//正确,可能会问,12这个字面量在java中是int类型,但是 a 是byte类型,为什么不报错呢,因为,编译器知道12在byte范围内,所以自动转为(short)12,但如果赋值的是a = 200,那就错误了,因为编译器知道200是超出byte范围的(在编译的时候,编译器只知道常量的值,知道它是否超出范围,编译器不知道变量的值,所以无法判断一个变量是否超出范围,因为变量的值是在运行的时候确定的) 9 10 a = Byte.MAX_VALUE +1;//报错 11 b = Short.MAX_VALUE +1;//报错 12 c = Char.MAX_VALUE +1;//报错 13 //上述三行报错原因是因为,byte,short,char三个类型参与计算时首先会提升为int类型,但在C语言当中(char和short类型)参与计算时不会被提升,所以在C语言中值为 -1 14 d = Integer.MAX_VALUE +1;//值为-1 15 e = Long.MAX_VALUE +1;//值为-1L 16 //因为int和long类型不存在提升,所以会出现-1或-1L