1.二進制字面量
JDK7開始,終於可以用二進制來表示整數(byte,short,int和long)。使用二進制字面量的好處是,可以是代碼更容易被理解。語法非常簡單,只要在二進制數值前面加 0b或者0B
- byte nByte = (byte)0b0001;
- short nShort = (short)0B0010;
- int nInt = 0b0011;
- long nLong = 0b0100L;
2.數字字面量可以出現下劃線
對於一些比較大的數字,我們定義起來總是不方面,經常缺少或者增加位數。JDK7爲我們提供了一種解決方案,下劃線可以出現在數字字面量。
注意:你只能將下劃線置於數字之間,以下使用方法是錯誤的,
1.數字的開頭或者結尾
2.小數點的前後
3.‘F’或者‘f’的後綴
4.只能用數字的位置
3.switch 語句可以用字符串了
這個功能千呼萬喚,終於出來了
- 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.泛型實例的創建可以通過類型推斷來簡化
以後你創建一個泛型實例,不需要再詳細說明類型,只需用<>,編譯器會自動幫你匹配
- //例如
- Map<String, List<String>> myMap = new HashMap<String, List<String>>();
- //可以簡化爲
- Map<String, List<String>> myMap = new HashMap<>();
5.在可變參數方法中傳遞非具體化參數(Non-Reifiable Formal Parameters),改進編譯警告和錯誤
有些參數類型,例如ArrayList<Number> 和 List<String>,是非具體化的(non-reifiable).在編譯階段,編譯器會擦除該類型信息。
Heappollution 指一個變量被指向另外一個不是相同類型的變量。例如
- List l = new ArrayList<Number>();
- List<String> ls = l; // unchecked warning
- l.add(0, new Integer(42)); // another unchecked warning
- String s = ls.get(0); // ClassCastException is thrown
回到我們的主題,在jdk7中,當你定義下面的函數時
- public static <T> void addToList (List<T> listArg, T... elements) {
- for (T x : elements) {
- listArg.add(x);
- }
- }
你會得到一個warning
warning: [varargs] Possible heap pollution from parameterized vararg type
在jdk7之前,當你調用一個含有非具體化參數的可變參數方法,你必須自行保證不會發生“heappollution”。這有一個問題,如果調用者對方法不熟悉,他根本無法判斷。JDK7對此做了改進,在該方法被定義時久發出警告
要消除警告,可以有三種方式
1.加 annotation @SafeVarargs
2.加 annotation @SuppressWarnings({"unchecked", "varargs"})
3.使用編譯器參數 –Xlint:varargs;
6.try-with-resources 語句
jdk7提供了try-with-resources,可以自動關閉相關的資源(只要該資源實現了AutoCloseable接口,jdk7爲絕大部分資源對象都實現了這個接口)
- static String readFirstLineFromFile(String path) throws IOException {
- try (BufferedReader br = new BufferedReader(new FileReader(path))) {
- return br.readLine();
- }
- }
try 語句塊中還可以同時處理多個資源,可以跟普通的try語句一樣catch異常,有finally語句塊
- 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。這時,代碼就不那麼優雅了,例如
- catch (IOException ex) {
- logger.log(ex);
- throw ex;
- catch (SQLException ex) {
- logger.log(ex);
- throw ex;
- }
Jdk7允許捕獲多個異常
注意,catch後面的異常參數是final的,不能重新再複製
RethrowException更具包容性的類型檢測
當你重新拋出多個異常時,不再需要詳細定義異常類型了,編譯器已經知道你具體拋出的是哪個異常了。你只需在方法定義的時候聲明需要拋出的異常即可
- public void call() throws ReflectiveOperationException, IOException {
- try {
- callWithReflection(arg);
- } catch (final Exception e) {
- logger.trace("Exception in reflection", e);
- throw e;
- }
- }
參考資料
Jdk7官網 http://openjdk.java.net/projects/jdk7/
(注:這篇文章發表時,JDK7未正式公佈,可能有誤差,具體以官方正式版爲準)