1、可以把转换想象成可乐瓶
byte < short < int < long < float < double
< char
小可乐 < 中可乐 < 大可乐
上面呢数据类型是由小向大排列。
byte c1 = 4;
int c2 = c1; //可以正常运行
byte类型c1的值赋值给int类型的c2,相当于将小瓶的可乐倒进大瓶子里,完全可以。
int c3 = 5;
byte c4 = c3; //编译会报错;错误: 不兼容的类型: 从int转换到byte可能会有损失
int类型c3的byte类型的c4,相当于将大瓶的可乐倒进小瓶子里,肯定是装不满的,溢出。
以此类推,数据类型较小的可以赋值给数据类型较大的,反之就会承受不了;
2、关于两个char类型相加会转换成int类型
两个char类型相加的时候,c1和c2会转成数字相加,所以相加的'a'和'b'是整数相加,故而是int类型。
char c1 = 'a'; //两个char类型
char c2 = 'b';
char c3 = c1 + c2; //相加时会报错
System.out.println(c1 + c2); //println可以支持各种数据类型的输出
3、强制类型转换的格式:
(强制转换后的类型)变量
(强制转换后的类型)常量值
(强制转换后的类型)(表达式) 把表达式计算结果转换为某个类型
int c4 = 5;
byte c5 = (byte)c4; //数据类型大的转数据类型小的时候要在值前面加(转换的数据类型)
int b1 = 1;
int b2 = 2;
byte b3 = (byte)(b1 + b2); //强制类型转换后面如果是表达式,需要加括号
这个强制类型转换有风险,可能会发生溢出或损失精度,结果不正确。
int x = 1;
int y = 2;
System.out.println(x/y);//结果是0
//整数 除以 整数,结果也是整数类型
//整个计算没有小数类型参与,不会自动升级为小数
System.out.println((double)x/y);//结果是0.5
//先把x升级为double,然后double/int,都升级为double,结果也是douoble
System.out.println((double)(x/y)); //结果是0.0
//先计算x/y,int/int,结果是int的0
//然后把0升级为double类型的0.0
如上图所示:x与y相除,本因该是0.5,但因为是int整数类型,导致结果为0,所以要提升为小数,把变量x由int升级为double,(double)计算中如果有一个值变量提升,那么其他几个变量也都会提升。如果表达式()括起来,那么提升的将会是括号(x/y)里面运算后的值。