byte在计算机中都会默认转为int进行计算。
第一个、第二个是直接赋值没有疑问。
第三个,左边两个原先定义的是byte类型,但是计算机会把他们转成int再计算。所以两个int相加,还是int,把int值赋给byte就会降低精度,所以报错。从eclispe的提示也可以得知:
第四个也是赋值,左边写多少个整数都没影响。只要左边的整数不超过127就行。byte整数最大表示到127。即byte 5=128就会报错。
在给你举个例子byte b5 = b1 + 20;也会报错,b1是byte型,20是int型,和高精度的数进行运算,会被进行类型提升,即低精度byte和高精度int的运算结果是高精度int,所以这个int结果不能赋给buye类型的变量。
|
|