编译器的2点优化
優(yōu)化1
對于byte/short/char三種類型來說,如果右側賦值的數值沒有超過范圍,那么javac編譯器將會自動隱含地為我們補上一個(byte)(short)(char)。
- 如果沒有超過左側的范圍,編譯器補上強轉。
- 如果右側超過了左側范圍,那么直接編譯器報錯。
代碼舉例
public class Demo12Notice {public static void main(String[] args) {// 右側確實是一個int數字,但是沒有超過左側的范圍,就是正確的。// int --> byte,不是自動類型轉換byte num1 = /*(byte)*/ 30; // 右側沒有超過左側的范圍 System.out.println(num1);// byte num2 = 128; // 右側超過了左側的范圍,直接報錯// int --> char,沒有超過范圍// 編譯器將會自動補上一個隱含的(char)char zifu = /*(char)*/ 65;System.out.println(zifu);} }執(zhí)行結果
優(yōu)化2
在給變量進行賦值的時候,如果右側的表達式當中全都是常量,沒有任何變量,那么編譯器javac將會直接將若干個常量表達式計算得到結果。例如:short result = 5 + 8; // 等號右邊全都是常量,沒有任何變量參與運算編譯之后,得到的.class字節(jié)碼文件當中相當于【直接就是】:short result = 13;右側的常量結果數值,沒有超過左側范圍,所以正確。這稱為“編譯器的常量優(yōu)化”。但是注意:一旦表達式當中有變量參與,那么就不能進行這種優(yōu)化了。
代碼舉例
public class Demo13Notice {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; 錯誤,不能常量優(yōu)化 } }執(zhí)行結果
?
?
轉載于:https://www.cnblogs.com/wurengen/p/11204352.html
總結
- 上一篇: 你所忽略的,覆盖equals时需要注意的
- 下一篇: 结巴分词1--结巴分词系统介绍