[size=x-small]
byte b=-128;
byte b=127;
都是可以编译通过的,在这里-128和127两个常量都是byte类型的,jvm会处理这个过程。
byte b=128;
编译不通过的,Type mismatch: cannot convert from int to byte
因为128已经超过byte的最大表示,jvm无法把这个常量当做byte,就默认当做int处理,则出现类型不匹配的错误。
同理,short的处理也是一样的。
宽类型 缩小为 窄数字类型时,就保留最后几位,符号位可能也发生变化。
例如1111 1111 0111 1111--》0111 1111
在java中,用十六进制表示数时默认是int类型的,如果第1位 置为1,则是负整数。
byte数组转化成int的时候,需要对每个byte都和0xff做与运算,例如byte[1]可能存在符号位扩展,但是例如byte[1]是属于int内存中的一块(相当于无符号数,都是正数),不能进行符号位扩展,所以需要0xff处理。
[/size]
byte b=-128;
byte b=127;
都是可以编译通过的,在这里-128和127两个常量都是byte类型的,jvm会处理这个过程。
byte b=128;
编译不通过的,Type mismatch: cannot convert from int to byte
因为128已经超过byte的最大表示,jvm无法把这个常量当做byte,就默认当做int处理,则出现类型不匹配的错误。
同理,short的处理也是一样的。
宽类型 缩小为 窄数字类型时,就保留最后几位,符号位可能也发生变化。
例如1111 1111 0111 1111--》0111 1111
在java中,用十六进制表示数时默认是int类型的,如果第1位 置为1,则是负整数。
byte数组转化成int的时候,需要对每个byte都和0xff做与运算,例如byte[1]可能存在符号位扩展,但是例如byte[1]是属于int内存中的一块(相当于无符号数,都是正数),不能进行符号位扩展,所以需要0xff处理。
[/size]