一、基本类型之间的转换概念
整形 | byte | short | int | long |
浮点型 | float | double | ||
字符型 | char | |||
布尔型 | boolean |
数据类型 | 占用字节 | 取值范围 | 缺省默认值 |
byte(字节型) | 1 | [-27~27-1]、[-128~127] | 0 |
short(短整型) | 2 | [-215~215-1]、[-32768~32767] | 0 |
int(整型) | 4 | [-231~231-1]、[-2147483648~2147483647] | 0 |
long(长整型) | 8 | [-263~263-1] | 0L |
float(单精度) | 4 | [-231~231-1] | 0.0f |
double(双精度) | 8 | [-263~263-1] | 0.0 |
char(字符型) | 2 | [0~216-1]、[0~65535] | ‘\u0000’ |
boolean(布尔型) | 1 | true / flase | flase |
切记:
1 八种基本数据类型,除了boolean不能转换,剩下的七种之间都可以进行转换;
2 如果整数数字字面量没有超出 byte short char 它们的取值范围,
可以直接将其赋值给 byte short char 类型的变量
3小容量向大容量转换的时候自动类型转换
byte<short(char)<int<long<float<double
short char 都占用2个字节,但是char类型可以表示更大的数字!!!
4大容量转换为小容量,称为强制类型转换!!!【丢失精度!!谨慎使用最好不用】
5 byte short char三种类型混合运算的时候,先各自的转换为int类型再进行运算
6多种类型进行运算各自先转换为容量最大的那一种再进行运算
二、强制类型转换(大转小)
类型转换都是小范围向大范围转换的,大范围往小范围转化需要用到强制转换,转换后的值会有所损失。
不同数据类型精度由小到大排列如下:char-->byte --> short --> int --> long --> float --> double
*************************************************************************************************************
插入:为什么两次范围排序不一样呢?,主要原因是因为范围问题,我们已知道的byte范围是-128~127,而char的范围是0~65535,两者范围如下图所示:
所以在byte与char的转换时互为强转
*********************************************************************************************************
当 像是int转向为byte时,如果int的值超过了byte的范围,就会出现数据缺失。
public class Test{
public static void main(String[] args){
byte b3=(byte)300;
System.out.println(b3);
}
}
可以看到,经过强制转换后的100变为了44,原理如下:
int型数值的存储大小为4字节,byte为1字节,那么
int型 100 的二进制数为00000000 00000000 00000001 0010 1100,强制转换为byte型数值后,它的二进制数就会变为1字节,前面的3个字节都会被损失掉,即变为 0010 1100
两个相加不超范围的byte数
public class Test{
public static void main(String[] args){
byte b7=50;
byte b8=50;
byte b9=b7+b8;
System.out.println(b9);
}
}
可以很明显看到无论是运行还是不运行时都会报错,这是因为b9并不知道b7和b8是什么类型的数值,所以为了避免出现二义性,该程序不予以计算