Ausnahmebehandlung in Java: Die Auswirkungen von in Catch- und Final-Klauseln geworfenen Ausnahmen verstehen
Bedenken Sie den folgenden Codeausschnitt:
class MyExc1 extends Exception {} class MyExc2 extends Exception {} class MyExc3 extends MyExc2 {} 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(); // throws MyExc1 here } } static void q() throws Exception { try { throw new MyExc1(); // throws MyExc1 here } catch (Exception y) { } finally { System.out.print(3); throw new Exception(); // throws Exception here } } }
In diesem Snippet sehen wir eine Folge von Ausnahmen, die sowohl in der Try-Catch- als auch in der Final-Klausel ausgelöst werden. Die erwartete Ausgabe ist „132Exception in Thread main MyExc1“, nicht „13Exception in thread main MyExc2“.
Um dieses Ergebnis zu verstehen, muss man das Grundprinzip der Ausnahmebehandlung in Java verstehen:
Wenn eine neue Ausnahme innerhalb einer Catch- oder Final-Klausel ausgelöst wird, die aus diesem Block heraus weitergegeben wird, wird die aktuelle Ausnahme abgebrochen und stattdessen die neue Ausnahme weitergegeben.
Im Wesentlichen wird die aktuelle Ausnahme vergessen. und die neue Ausnahme übernimmt den Abwicklungsprozess im Stapel.
Im angegebenen Code wird eine MyExc1-Ausnahme in der innersten Final-Klausel ausgelöst. Diese Ausnahme wird schließlich bis zur Hauptklausel „final“ aufsteigen. In dieser final-Klausel wird jedoch eine weitere Ausnahme, MyExc1, ausgelöst, die die Weitergabe des ursprünglichen MyExc1 abbricht. Daher wird MyExc1 der äußersten Final-Klausel zur Ausnahme, die nach außen weitergegeben wird.
Das obige ist der detaillierte Inhalt vonWarum wird die im „finally'-Block ausgelöste Ausnahme in Java letztendlich gemeldet?. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!