/*
java中有一个语法规则:
当这个整数型字面量没有超出byte的取值范围,那么这个
整数型字面量可以直接赋值给byte类型的变量。
这种语法机制是为了方便写代码,而存在的。
*/
public class 精度损失以及不超范围可以直接赋值byte和short
{
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;
//byte z = 128;//错误不兼容的类型:从int转换到byte可能会有损失
// 当整数型字面量没有chaocshort类型取值范围的时候,该字面量可以直接赋值给short。
// 类型的变量
short s = 1;
short s1 = 32767;
// 错误:不兼容的类型:从int转换到short可能会有损失
//short s2 = 32768;
System.out.println(s);
}
}