/*
对于byte/short/char三种类型来说 如果右侧的赋值数值没有超范围
哪么javac 编译器的将会隐含的为我们补上一个byte short char 。
1 如果没有超过左侧的范围 编译器补上 强转
2 如果右侧超过了 左侧的范围 那么直接编译器报错
/
public class Demo34{
public static void main(String[] args){
//右侧确实是一个int数字 但是没有超过左侧的范围 就是正确的
//Int–>byte 不是自动类型转换
byte num1 = /(byte)*/ 30;//右侧没有超过左侧的范围
System.out.println(num1);//30
//byte num2 = 128;//右侧超过了左侧的范围
//int --> char;没有超过范围
//编译器将会自动补上一个隐含的 char
char zifu = /*(char)*/65;
System.out.println(zifu);//A
}
}
代码截图
/*
在给变量进行赋值的时候 如果右侧的表达式当中全部是常量 没有任何变量的
那么编译器的javac将会直接将若干个常量表达式计算得到结果
short result = 5 + 8;//等号右边全是常量 没有任何的变量参与运算
编译之后得到的 .class 字节码文件相当于直接就是
short result = 13;
右侧的常量结果数值 没有超过左侧的范围 所以正确
这个叫做编译器的常量优化
但是 注意了 一旦表达式中有变量参与 那么不能进行这样的优化了
*/
public class demo35{
public static void main(String[] args){
short num1 = 10;//正确写法 右侧没有超过左侧的范围
short a = 5;
short b = 8;
//short + short --> int + int -->int
//short result = a + b;//错误写法!左侧需要那个是int型
//右侧不需要任何变量 而是采用常量 而且只有二个常量 没有别人
short result = 5 + 8;
System.out.println(result);
//short result2 = 5 + a + 8;//18
}
}
代码截图