Heim >Java >javaLernprogramm >Warum erzeugt das Code-Snippet die Ausgabe „132Exception in thread main MyExc1', obwohl im Catch-Block eine MyExc2-Ausnahme ausgelöst wird?

Warum erzeugt das Code-Snippet die Ausgabe „132Exception in thread main MyExc1', obwohl im Catch-Block eine MyExc2-Ausnahme ausgelöst wird?

Barbara Streisand
Barbara StreisandOriginal
2024-10-29 22:30:29812Durchsuche

Why does the code snippet produce the output

Ausnahmebehandlung in Catch- und Final-Blöcken

Bei einer aktuellen Java-Aufgabe an einer Universität stieß ein Student auf den folgenden Codeausschnitt und wurde gebeten, ihn vorherzusagen seine Ausgabe:

<code class="java">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();
        }
    }

    static void q() throws Exception {
        try {
            throw new MyExc1();
        }
        catch (Exception y) {
        }
        finally {
            System.out.print(3);
            throw new Exception();
        }
    }
}</code>

Als der Schüler mit „13Exception in Thread main MyExc2“ antwortete, waren sie überrascht, als sie herausfanden, dass die richtige Antwort „132Exception in thread main MyExc1“ war.

Ausnahmeausbreitung in Catch- und Final-Blöcken verstehen

Um die korrekte Ausgabe zu verstehen, ist es wichtig, das Verhalten von Ausnahmen in Catch- und Final-Blöcken zu verstehen. Gemäß dem Ausnahmebehandlungsmechanismus von Java:

  1. Wenn eine Ausnahme innerhalb eines Catch- oder Final-Blocks ausgelöst wird, die aus diesem Block heraus weitergegeben wird, wird die aktuelle Ausnahme automatisch abgebrochen und vergessen.
  2. Die neue Ausnahme beginnt mit dem Abwickeln des Stapels und hält sich dabei an alle Catch- oder Final-Blöcke.
  3. Bemerkenswert ist, dass eine neue Ausnahme, die in einem Catch-Block ausgelöst wird, immer noch dem Final-Block dieses Catchs unterliegt, falls vorhanden.

Ausnahmefluss verfolgen

Vor diesem Hintergrund verfolgen wir die Ausführung des Code-Snippets Schritt für Schritt:

  • Die Das Programm startet in der Hauptmethode und gibt „1“ aus.
  • Eine Ausnahme wird in der q-Methode ausgelöst und vom Catch-Block in Main abgefangen.
  • Im Catch-Block wird eine neue Ausnahme erstellt. MyExc2, wird geworfen. Dadurch wird die ursprüngliche Ausnahme MyExc1 abgebrochen.
  • Die MyExc2-Ausnahme wird aus dem Catch-Block in den Final-Block weitergegeben.
  • Der Final-Block gibt „2“ aus. Vor dem Verlassen der q-Methode löst der „final“-Block jedoch eine neue Ausnahme aus, die mit dem Abwickeln des Stapels beginnt.
  • Die neue Ausnahme ist eine Ausnahme, die nicht im Catch-Block der q-Methode abgefangen wird.
  • Die Exception-Ausnahme breitet sich aus der q-Methode in den „finally“-Block in der „main“-Methode aus.
  • Der „finally“-Block in der „main“-Methode gibt „3“ aus und löst dann eine „MyExc1“-Ausnahme aus.
  • Die Die MyExc1-Ausnahme breitet sich aus der Hauptmethode aus und wird von der virtuellen Maschine abgefangen.

Verstehen der Ausgabe

Aus dieser Ablaufverfolgung können wir Folgendes erkennen:

  • Die letzte Ausnahme, die sich aus der Hauptmethode heraus verbreitet, ist MyExc1.
  • Der Stack-Trace enthält „132“, was der vom Programm gedruckten Ausgabe entspricht.

Daher lautet die korrekte Ausgabe „132Exception in thread main MyExc1.“

Das obige ist der detaillierte Inhalt vonWarum erzeugt das Code-Snippet die Ausgabe „132Exception in thread main MyExc1', obwohl im Catch-Block eine MyExc2-Ausnahme ausgelöst wird?. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Stellungnahme:
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn