您好,登錄后才能下訂單哦!
JDK7新特性的語法是什么,很多新手對此不是很清楚,為了幫助大家解決這個難題,下面小編將為大家詳細講解,有這方面需求的人可以來學習下,希望你能有所收獲。
JDK7對Java語法有少量更新,重點是在易用性和便捷性的改進。
1.二進制字面量
JDK7開始,終于可以用二進制來表示整數(byte,short,int和long)。使用二進制字面量的好處是,可以是代碼更容易被理解。語法非常簡單,只要在二進制數值前面加 0b或者0B
Java代碼
byte nByte = (byte)0b0001; short nShort = (short)0B0010; int nInt = 0b0011; long nLong = 0b0100L;
2.數字字面量可以出現下劃線
對于一些比較大的數字,我們定義起來總是不方面,經常缺少或者增加位數。JDK7為我們提供了一種解決方案,下劃線可以出現在數字字面量。
Java代碼
int a = 10_0000_0000; long b = 0xffff_ffff_ffff_ffffl; byte c = 0b0001_1000;
注意:你只能將下劃線置于數字之間,以下使用方法是錯誤的,
1.數字的開頭或者結尾
2.小數點的前后
3.‘F’或者‘f’的后綴
4.只能用數字的位置
Java代碼
int err1 = _11,err2=11_; float err3=3._4,err4=3_.4; long err5=0x888_f;
3.switch 語句可以用字符串了
這個功能千呼萬喚,終于出來了
Java代碼
private static void switchString(String str){ switch(str){ case "one": System.err.println("1"); break; case "two": System.out.println("2"); break; default : System.out.println("err"); } }
4.泛型實例的創建可以通過類型推斷來簡化
以后你創建一個泛型實例,不需要再詳細說明類型,只需用<>,編譯器會自動幫你匹配
Java代碼
//例如 Map<STRING, LIST> myMap = new HashMap<STRING, LIST>(); //可以簡化為 Map<STRING, LIST> myMap = new HashMap<>();
5.在可變參數方法中傳遞非具體化參數(Non-Reifiable Formal Parameters),改進編譯警告和錯誤
有些參數類型,例如ArrayList
Heap pollution 指一個變量被指向另外一個不是相同類型的變量。例如
Java代碼
List l = new ArrayList(); List ls = l; // unchecked warning l.add(0, new Integer(42)); // another unchecked warning String s = ls.get(0); // ClassCastException is thrown
回到我們的主題,在jdk7中,當你定義下面的函數時
Java代碼
public static void addToList (List listArg, T... elements) { for (T x : elements) { listArg.add(x); } }
你會得到一個warning
warning: [varargs] Possible heap pollution from parameterized vararg type
在jdk7之前,當你調用一個含有非具體化參數的可變參數方法,你必須自行保證不會發生“heap pollution”。這有一個問題,如果調用者對方法不熟悉,他根本無法判斷。JDK7對此做了改進,在該方法被定義時久發出警告
要消除警告,可以有三種方式
1.加 annotation @SafeVarargs
2.加 annotation @SuppressWarnings({"unchecked", "varargs"})
3.使用編譯器參數 –Xlint:varargs;
6.try-with-resources 語句
jdk7提供了try-with-resources,可以自動關閉相關的資源(只要該資源實現了AutoCloseable接口,jdk7為絕大部分資源對象都實現了這個接口)
Java代碼
static String readFirstLineFromFile(String path) throws IOException { try (BufferedReader br = new BufferedReader(new FileReader(path))) { return br.readLine(); } }
try 語句塊中還可以同時處理多個資源,可以跟普通的try語句一樣catch異常,有finally語句塊
Java代碼
try ( java.util.zip.ZipFile zf = new java.util.zip.ZipFile(zipFileName); java.io.BufferedWriter writer = java.nio.file.Files.newBufferedWriter(outputFilePath, charset) ) { }catch(…){ }finally{ }
7.Catch多個Exception,rethrow exception 改進了類型檢測
很多時候,我們捕獲了多個異常,卻做了相同的事情,比如記日志,包裝成新的異常,然后rethrow。這時,代碼就不那么優雅了,例如
Java代碼
catch (IOException ex) { logger.log(ex); throw ex; catch (SQLException ex) { logger.log(ex); throw ex; }
Jdk7允許捕獲多個異常
Java代碼
catch (IOException|SQLException ex) { logger.log(ex); throw ex; }
注意,catch后面的異常參數是final的,不能重新再復制
Rethrow Exception更具包容性的類型檢測
當你重新拋出多個異常時,不再需要詳細定義異常類型了,編譯器已經知道你具體拋出的是哪個異常了。你只需在方法定義的時候聲明需要拋出的異常即可
Java代碼
public void call() throws ReflectiveOperationException, IOException { try { callWithReflection(arg); } catch (final Exception e) { logger.trace("Exception in reflection", e); throw e; } }
看完上述內容是否對您有幫助呢?如果還想對相關知識有進一步的了解或閱讀更多相關文章,請關注億速云行業資訊頻道,感謝您對億速云的支持。
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。