java中有一个语法规则:
当这个整数型字面量没有超出byte的取值范围,那么这个整数型字面量可以直接赋值给byte类型的字面量。<br /> <br />这种语法机制是为了方便写代码,而存在的。
public class IntTest04{ public static void main(String[] args){ // 分析:以下代码编写可以通过吗? // 300 被默认当做 int 类型 // b变量是byte类型 // 大容量转换成小容量,要想编译通过,必须使用强制类型转换符 //byte b = 300; // 要想让以上的程序编译通过,必须加强制类型转换符 // 虽然编译通过了,但是可能精度损失。 // 300 这个int类型对应的二进制:00000000 00000000 00000001 00101100 // byte占用1个字节,砍掉前3个字节,结果是:00101100 (44) byte b = (byte)300; System.out.println(b); // 44 // 这个编译能通过吗? // 1是int类型,默认被当做int类型来看。 // x是byte类型,1个字节,大容量无法直接转换成小容量。 // 按说是编译报错的 byte x = 1; byte y = 127; // 错误:不兼容的类型:从int转换到byte可能会有损失 byte z = 128; // 当整数型字面量没有超出short类型取值范围的时候,该字面量可以直接赋值给short类型的字面量。 short s = 1; short s1 = 32767; // 错误:不兼容的类型:从int转换到byte可能会有损失 //short s2 = 32768; }}