1.强制类型转换一般不推荐使用,因为有可能发生精度损失,数据溢出等情况!
数据溢出;
int num3 = (int)6000000000L;
System.out.println(num3);
运行情况;
为什会这样?
这张图明白了吗?
老话可以说撒了 呵呵。
精度损失;
int num4 = (int)3.5;
System.out.println(num4);
运行情况;
怎么回事?
难道是四舍五入?那不应该4才对啊。
所以强制转换类型会有一系列隐患,慎用。
2.byte/short/char这三种类型都可以发生数学运算,例如加法“+”。
char zifu1 = 'A'; // 这是一个字符变量
System.out.println(zifu1+1); // 66,也就是大写字母A被当做65进行处理
// 计算机的底层会用一个数字(二进制)来表示字符A
// 一旦char类型进行了数学运算,那么字符就会按照一定的规则翻译成为一个数字
运行结果;
这是一个字符变量, 66,也就是大写字母A被当做65进行处理
// 计算机的底层会用一个数字(二进制)来表示字符A
// 一旦char类型进行了数学运算,那么字符就会按照一定的规则翻译成为一个数字。
byte num5 = 40; // 注意 ! 右侧数值大小不能超过左侧得类型范围
byte num6 = 50;
// byte + byte --> int + int --> int
short result1 = num5 + num6;
System.out.println(result1);
运行情况;
因为他的逻辑是byte + byte –> int + int –> int,所以我们把short result1改成 int result1 就可以了。
short num7 = 60;
// byte + short --> int + int --> int
// int强制转换为short:注意必须保证逻辑上真实大小就没有超过short的范围,否则会发生数据溢出
short result2 = num6 + num7;
System.out.println(result2);
运行情况;
// byte + short –> int + int –> int
// int强制转换为short:注意必须保证逻辑上真实大小就没有超过short的范围,否则会发生数据溢出
不过我们改成这样就可以了
short num7 = 60;
// byte + short --> int + int --> int
// int强制转换为short:注意必须保证逻辑上真实大小就没有超过short的范围,否则会发生数据溢出
short result2 = (short)(num6 + num7);
System.out.println(result2);
或者
short num7 = 60;
// byte + short --> int + int --> int
// int强制转换为short:注意必须保证逻辑上真实大小就没有超过short的范围,否则会发生数据溢出
int result2 = num6 + num7;
System.out.println(result2);
运行结果;
版权声明:本文为weixin_50212958原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接和本声明。