Ausnahmebehandlung in Java: Die Mehrdeutigkeit aufdecken
In einem rätselhaften Java-Ausnahmebehandlungsszenario präsentierte eine Universitätsfrage den folgenden Codeausschnitt:
<code class="java">// Exception Heirarchy class MyExc1 extends Exception {} class MyExc2 extends Exception {} class MyExc3 extends MyExc2 {} // Main Class public class C1 { public static void main(String[] args) throws Exception { try { System.out.print(1); q(); } catch (Exception i) { throw new MyExc2(); } finally { System.out.print(2); throw new MyExc1(); } } static void q() throws Exception { try { throw new MyExc1(); } catch (Exception y) { } finally { System.out.print(3); throw new Exception(); } } }</code>
Die Frage wurde nach ihrer Ausgabe gefragt und die Antwort war „13Exception in Thread main MyExc2“. Die richtige Antwort lautet jedoch „132Exception in thread main MyExc1“.
Klärung der Mehrdeutigkeit
Um dieses Rätsel zu lösen, ist es wichtig, die Vorrangstellung von Ausnahmen zu verstehen:
Konsequenzen :
Rückverfolgung der Ausführung
Anwenden dieses Prinzips auf den Code:
Erste Ausführung:
Catch-Block Ausnahme:
Ausführung wird im Try-Block von Main fortgesetzt:
Finally-Block-Ausnahme:
Ausgabe:
Die endgültige Ausgabe ist „132Exception in Thread main MyExc1“, weil die Ausnahme, die sich nach außen ausbreitet der Hauptmethode ist das in Zeile 16 geworfene MyExc1. Das in Zeile 19 geworfene MyExc2 wird abgebrochen, wenn MyExc1 in Zeile 16 geworfen wird.
Das obige ist der detaillierte Inhalt vonWarum erzeugt der Java-Ausnahmebehandlungscode „132Exception in Thread Main MyExc1' anstelle von „13Exception in Thread Main MyExc2'?. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!