1.整数类型
例1如下图是一个简单的byte类型数据运算.
该程序看似没有错误,当我运行时会发现运行出错
这是因为a和b都是byte类型,a和b都在byte的表示范围内,而a+b可能会超出这个范围,虽然“1”和“3”相加也在这个范围内,但是在编译时系统会默认将后面的数字看成最大表示值,这样会使转换时有数据损失,所以系统将会报错。
解决方案:将byte c=a+b;前面的byte替换为short c=a+b;
例2如同是int类型的运算
在这个程序中我们将a和b赋值为int类型所能表示的最大整数
上图为编译和运行过程,我们发现在编译和运行时并没有报错,但是显然答案是错的。
这是因为赋值号后面的数字都默认为int类型,所以不存在数据的强制类型转换,所以系统会认为int转换为int不会有数据丢失。
这些东西才是我们在编程中应该更加注意的,解决方法为:可以将int c=a+b;改成long c=a+b;