编译器的常量优化
/* 在给变量进行赋值的时候,如果右侧表示当中全都是常量,没有任何变量,那么编译器javac将会直接将若干个常量表达式计算得到结果。 short c = 1 + 2; //等号右边全都是常量,没有任何变量参与运算,编译之后,得到的.class字节码文件相当于【直接就是】:short c = 3 右侧的常量结果数值,没有超过左侧范围,所以正确。 这称为"编译器的常量优化" 但是注意:一旦表达式当中有变量的参与,那么就不能进行这种优化了。 */ public class Test { public static void main(String[] args) { short num = 20; //正确写法,右侧没有超过左侧范围。 short a = 1; short b = 2; // short + short --> int + int --> int // short c = a + b; //错误写法!左侧需要是int类型 short c = 1 + 2; // 可以!右侧不用变量,而是采用常量 System.out.println(c); } }
/* 对于byte/short/char三种类型来说,如果右侧赋值的数值没有超过范围, 那么javac编译器将会自动隐含地为我们补上一个(byte)(short)(char)。 1. 如果没有超过左侧的范围,编译器补上强转。 2. 如果右侧超过了左侧范围,那么直接编译器报错。 */ public class Test2 { public static void main(String[] args) { // 右侧是一个int数字,但是没有超过左侧的范围,就是正确的 // int --> byte 不是自动类型转换 byte num = /*(byte)*/30; System.out.println(num); // int --> char 没有超过范围 // 编译器会自动补上一个隐含的(char) char zifu = 65; System.out.println(zifu); } }
相关推荐
hjr 2020-05-31
天步 2020-04-22
NapoleonBai 2020-05-01
chinawangfei 2020-04-11
amberom 2020-03-28
linmufeng 2020-02-18
GoatSucker 2020-02-16
wujingsheng0 2020-02-10
AndroidAmelia 2020-01-30
lsfreeing 2020-01-10
evanbai 2013-03-22
oXiaoChong 2019-12-23
luckymaoyy 2019-12-20
sunnyJam 2019-12-10
狼窝 2019-11-30
galoisgodel 2012-02-04
葫芦小金刚 2019-09-05
84086320 2011-11-29
taiyangshenniao 2019-07-01