異常
74. throw 和 throws 的區別?
throws是用來聲明一個方法可能拋出的所有異常信息,throws是將異常聲明但是不處理,而是將異常往上傳,誰調用我就交給誰處理。而throw則是指拋出的一個具體的異常類型。
75. final、finally、finalize 有什么區別?
-
final可以修飾類、變量、方法,修飾類表示該類不能被繼承、修飾方法表示該方法不能被重寫、修飾變量表示該變量是一個常量不能被重新賦值。
-
finally一般作用在try-catch代碼塊中,在處理異常的時候,通常我們將一定要執行的代碼方法finally代碼塊中,表示不管是否出現異常,該代碼塊都會執行,一般用來存放一些關閉資源的代碼。
-
finalize是一個方法,屬於Object類的一個方法,而Object類是所有類的父類,該方法一般由垃圾回收器來調用,當我們調用System的gc()方法的時候,由垃圾回收器調用finalize(),回收垃圾。
76. try-catch-finally 中哪個部分可以省略?
答:catch 可以省略
原因:
更為嚴格的說法其實是:try只適合處理運行時異常,try+catch適合處理運行時異常+普通異常。也就是說,如果你只用try去處理普通異常卻不加以catch處理,編譯是通不過的,因為編譯器硬性規定,普通異常如果選擇捕獲,則必須用catch顯示聲明以便進一步處理。而運行時異常在編譯時沒有如此規定,所以catch可以省略,你加上catch編譯器也覺得無可厚非。
理論上,編譯器看任何代碼都不順眼,都覺得可能有潛在的問題,所以你即使對所有代碼加上try,代碼在運行期時也只不過是在正常運行的基礎上加一層皮。但是你一旦對一段代碼加上try,就等於顯示地承諾編譯器,對這段代碼可能拋出的異常進行捕獲而非向上拋出處理。如果是普通異常,編譯器要求必須用catch捕獲以便進一步處理;如果運行時異常,捕獲然后丟棄並且+finally掃尾處理,或者加上catch捕獲以便進一步處理。
至於加上finally,則是在不管有沒捕獲異常,都要進行的“掃尾”處理。
77. try-catch-finally 中,如果 catch 中 return 了,finally 還會執行嗎?
答:會執行,在 return 前執行。
代碼示例1:
/* * java面試題--如果catch里面有return語句,finally里面的代碼還會執行嗎? */ public class FinallyDemo2 { public static void main(String[] args) { System.out.println(getInt()); } public static int getInt() { int a = 10; try { System.out.println(a / 0); a = 20; } catch (ArithmeticException e) { a = 30; return a; /* * return a 在程序執行到這一步的時候,這里不是return a 而是 return 30;這個返回路徑就形成了 * 但是呢,它發現后面還有finally,所以繼續執行finally的內容,a=40 * 再次回到以前的路徑,繼續走return 30,形成返回路徑之后,這里的a就不是a變量了,而是常量30 */ } finally { a = 40; } // return a; } }
執行結果:30
代碼示例2:
1 package com.java_02; 2 3 /* 4 * java面試題--如果catch里面有return語句,finally里面的代碼還會執行嗎? 5 */ 6 public class FinallyDemo2 { 7 public static void main(String[] args) { 8 System.out.println(getInt()); 9 } 10 11 public static int getInt() { 12 int a = 10; 13 try { 14 System.out.println(a / 0); 15 a = 20; 16 } catch (ArithmeticException e) { 17 a = 30; 18 return a; 19 /* 20 * return a 在程序執行到這一步的時候,這里不是return a 而是 return 30;這個返回路徑就形成了 21 * 但是呢,它發現后面還有finally,所以繼續執行finally的內容,a=40 22 * 再次回到以前的路徑,繼續走return 30,形成返回路徑之后,這里的a就不是a變量了,而是常量30 23 */ 24 } finally { 25 a = 40; 26 return a; //如果這樣,就又重新形成了一條返回路徑,由於只能通過1個return返回,所以這里直接返回40 27 } 28 29 // return a; 30 } 31 }
執行結果:40
78. 常見的異常類有哪些?
-
NullPointerException:當應用程序試圖訪問空對象時,則拋出該異常。
-
SQLException:提供關於數據庫訪問錯誤或其他錯誤信息的異常。
-
IndexOutOfBoundsException:指示某排序索引(例如對數組、字符串或向量的排序)超出范圍時拋出。
-
NumberFormatException:當應用程序試圖將字符串轉換成一種數值類型,但該字符串不能轉換為適當格式時,拋出該異常。
-
FileNotFoundException:當試圖打開指定路徑名表示的文件失敗時,拋出此異常。
-
IOException:當發生某種I/O異常時,拋出此異常。此類是失敗或中斷的I/O操作生成的異常的通用類。
-
ClassCastException:當試圖將對象強制轉換為不是實例的子類時,拋出該異常。
-
ArrayStoreException:試圖將錯誤類型的對象存儲到一個對象數組時拋出的異常。
-
IllegalArgumentException:拋出的異常表明向方法傳遞了一個不合法或不正確的參數。
-
ArithmeticException:當出現異常的運算條件時,拋出此異常。例如,一個整數“除以零”時,拋出此類的一個實例。
-
NegativeArraySizeException:如果應用程序試圖創建大小為負的數組,則拋出該異常。
-
NoSuchMethodException:無法找到某一特定方法時,拋出該異常。
-
SecurityException:由安全管理器拋出的異常,指示存在安全侵犯。
-
UnsupportedOperationException:當不支持請求的操作時,拋出該異常。
-
RuntimeExceptionRuntimeException:是那些可能在Java虛擬機正常運行期間拋出的異常的超類。