Catch 및 finally 블록의 예외 전파
Java 프로그램에서 예외가 발생하면 처리될 때까지 스택을 통해 전파됩니다. 적절한 catch 블록을 사용하거나 프로그램을 종료합니다. 그러나 예외는 catch 또는 finally 블록 내에서 발생할 수도 있으므로 전파 동작에 대한 의문이 제기됩니다.
다음 코드 조각을 고려하세요.
<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(); // Exception thrown in catch block } finally { System.out.print(2); throw new MyExc1(); // Exception thrown in finally block } } static void q() throws Exception { try { throw new MyExc1(); } catch (Exception y) { } finally { System.out.print(3); throw new Exception(); // Exception thrown in finally block } } }</code>
catch 또는 finally 블록 내에서 예외가 발생하는 경우 finally 블록에는 다음 원칙이 적용됩니다.
예외 재정의: 해당 블록 외부로 전파하려는 catch 또는 finally 블록 내에서 새 예외가 발생하는 경우 현재 예외가 진행 중입니다. 중단되고 새로운 예외가 외부로 전파되어 그 자리를 대신하게 됩니다. 중단된 예외는 삭제됩니다.
제공된 코드에서 catch 및 finally 블록의 예외 시나리오는 다음 원칙을 보여줍니다.
결과적으로, 스택을 해제한 후 프로그램 실행이 기본 메서드에 도달하면 MyExc2 예외는 다음과 같습니다. MyExc1에 의해 재정의되었으며 이후에 인쇄 및 처리됩니다. 따라서 올바른 출력은 "스레드 메인 MyExc1의 132Exception"입니다.
위 내용은 Java의 catch 및 finally 블록 내에서 예외가 발생하는 경우 예외 전파는 어떻게 작동합니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!