编译器的两点优化-java

对于byte/short/char 三种类型来说,如果右侧赋值的数据没有超过范围,那么javac编译器将会自动隐含地为我们补上一个强转(byte)(short) (char)

如果右侧超过了左侧的范围,那么直接编译器报错。

1
2
3
4
5
6
7
8
public class Main5 {
public static void main(String[] args) {
byte num = /*(byte)*/ 30;
System.out.println(num); //30
char ch = /*(char)*/ 65;
System.out.println(ch); // a
}
}

二.编译器的常量优化

在给变量进行赋值的时候,如果右侧的表达式中全部都是常量,没有任何变量,那么编译器javac将会直接将若干个常量表达式计算得到结果。

short result = 5 + 8;//等号右边全是常量,没有变量参与

编译之后得到的.class字节码文件中相当于 short result = 13;

右侧的常量的结果数值没有超过左侧的范围,所以正确。

这就称为”编译器的常量优化“;


注意:一旦表达式中有变量参与,那么就不能进行这种优化了。出现的错误也只能运行时发现了。

好处:一些有规律的数字比如以秒为计时单位的30天,就可以写成 60*60*24*30 ,不用去计算,也不用担心性能损耗,加快开发效率;另一点可以尽可能地发现并尽早处理运行时可能出现的问题。



编译器的两点优化-java
https://blog.wangxk.cc/2020/08/17/编译器的两点优化-java/
作者
Mike
发布于
2020年8月17日
许可协议