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;
}
}