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