int i = 1;
byte b = i;
如果写以上代码会出现错误,int类型占4个byte,而 i 是一个int型变量,所以第二句代码把int型变量赋值给byte型的变量,有可能会出现越界。
但是如果这样写
int i = 1;
byte b = (byte)i;
就不会报错,即使越界也会作处理。
如果i = 128 则 b = -128;
因为128 = 00000000 00000000 00000000 10000000;
-128 = 11111111 11111111 11111111 10000000;
只截取了后8位。
另外:
如果直接这样写:byte b = 1;
也不会报错,因为编译会提前做出判断会不会越界,如果越界则不会报错,如果越界则会报错,还需要强转。
如果byte b = 128;
则报错,需要强转。