探秘JDK7新特性之語法
JDK7對Java語法有少量更新,重點是在易用性和便捷性的改進。
1.二進制字面量
JDK7開始,終于可以用二進制來表示整數(shù)(byte,short,int和long)。使用二進制字面量的好處是,可以是代碼更容易被理解。語法非常簡單,只要在二進制數(shù)值前面加 0b或者0B
Java代碼
- byte nByte = (byte)0b0001;
- short nShort = (short)0B0010;
- int nInt = 0b0011;
- long nLong = 0b0100L;
2.數(shù)字字面量可以出現(xiàn)下劃線
對于一些比較大的數(shù)字,我們定義起來總是不方面,經(jīng)常缺少或者增加位數(shù)。JDK7為我們提供了一種解決方案,下劃線可以出現(xiàn)在數(shù)字字面量。
Java代碼
- int a = 10_0000_0000;
- long b = 0xffff_ffff_ffff_ffffl;
- byte c = 0b0001_1000;
注意:你只能將下劃線置于數(shù)字之間,以下使用方法是錯誤的,
1.數(shù)字的開頭或者結尾
2.小數(shù)點的前后
3.‘F’或者‘f’的后綴
4.只能用數(shù)字的位置
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.泛型實例的創(chuàng)建可以通過類型推斷來簡化
以后你創(chuàng)建一個泛型實例,不需要再詳細說明類型,只需用<>,編譯器會自動幫你匹配
Java代碼
- //例如
- Map
> myMap = new HashMap>(); - //可以簡化為
- Map
> myMap = new HashMap<>();
5.在可變參數(shù)方法中傳遞非具體化參數(shù)(Non-Reifiable Formal Parameters),改進編譯警告和錯誤
有些參數(shù)類型,例如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中,當你定義下面的函數(shù)時
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之前,當你調(diào)用一個含有非具體化參數(shù)的可變參數(shù)方法,你必須自行保證不會發(fā)生“heap pollution”。這有一個問題,如果調(diào)用者對方法不熟悉,他根本無法判斷。JDK7對此做了改進,在該方法被定義時久發(fā)出警告
要消除警告,可以有三種方式
1.加 annotation @SafeVarargs
2.加 annotation @SuppressWarnings({"unchecked", "varargs"})
3.使用編譯器參數(shù) –Xlint:varargs;
6.try-with-resources 語句
jdk7提供了try-with-resources,可以自動關閉相關的資源(只要該資源實現(xiàn)了AutoCloseable接口,jdk7為絕大部分資源對象都實現(xiàn)了這個接口)
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。這時,代碼就不那么優(yōu)雅了,例如
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后面的異常參數(shù)是final的,不能重新再復制
Rethrow Exception更具包容性的類型檢測
當你重新拋出多個異常時,不再需要詳細定義異常類型了,編譯器已經(jīng)知道你具體拋出的是哪個異常了。你只需在方法定義的時候聲明需要拋出的異常即可
Java代碼
- public void call() throws ReflectiveOperationException, IOException {
- try {
- callWithReflection(arg);
- } catch (final Exception e) {
- logger.trace("Exception in reflection", e);
- throw e;
- }
- }
參考資料
Jdk7官網(wǎng) http://openjdk.java.net/projects/jdk7/
(注:這篇文章發(fā)表時,JDK7未正式公布,可能有誤差,具體以官方正式版為準)
【編輯推薦】