Java の catch ブロックとfinally ブロック内で例外がスローされた場合、例外の伝播はどのように機能しますか?
Catch and Final Blocks での例外の伝播
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 ブロックでは、次の原則が適用されます:
例外のオーバーライド: 新しい例外が catch またはfinally ブロック内でスローされ、そのブロックから伝播することが意図されている場合、進行中の現在の例外は中止され、新しい例外が外側に伝播して、その代わりになります。中止された例外は破棄されます。
提供されたコードでは、catch ブロックとfinally ブロックの両方の例外シナリオが次の原則を示しています。
- Catch Block:例外 i が catch ブロック内でスローされると、すぐに新しい例外 MyExc2 に置き換えられ、処理中の例外になります。
- Finally Block: 同様に、例外がスローされると、 Finally ブロック内で、現在の MyExc2 例外を MyExc1 に置き換え、それを進行中の新しい例外にします。
その結果、プログラムの実行がスタックを巻き戻した後に main メソッドに到達すると、MyExc2 例外はMyExc1 によってオーバーライドされ、その後印刷および処理されます。したがって、正しい出力は「132Exception in thread main MyExc1.」です。
以上がJava の catch ブロックとfinally ブロック内で例外がスローされた場合、例外の伝播はどのように機能しますか?の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

ホットAIツール

Undresser.AI Undress
リアルなヌード写真を作成する AI 搭載アプリ

AI Clothes Remover
写真から衣服を削除するオンライン AI ツール。

Undress AI Tool
脱衣画像を無料で

Clothoff.io
AI衣類リムーバー

AI Hentai Generator
AIヘンタイを無料で生成します。

人気の記事

ホットツール

メモ帳++7.3.1
使いやすく無料のコードエディター

SublimeText3 中国語版
中国語版、とても使いやすい

ゼンドスタジオ 13.0.1
強力な PHP 統合開発環境

ドリームウィーバー CS6
ビジュアル Web 開発ツール

SublimeText3 Mac版
神レベルのコード編集ソフト(SublimeText3)

ホットトピック









Javaのクラスロードには、ブートストラップ、拡張機能、およびアプリケーションクラスローダーを備えた階層システムを使用して、クラスの読み込み、リンク、および初期化が含まれます。親の委任モデルは、コアクラスが最初にロードされ、カスタムクラスのLOAに影響を与えることを保証します

この記事では、カフェインとグアバキャッシュを使用してJavaでマルチレベルキャッシュを実装してアプリケーションのパフォーマンスを向上させています。セットアップ、統合、パフォーマンスの利点をカバーし、構成と立ち退きポリシー管理Best Pra

この記事では、キャッシュや怠zyなロードなどの高度な機能を備えたオブジェクトリレーショナルマッピングにJPAを使用することについて説明します。潜在的な落とし穴を強調しながら、パフォーマンスを最適化するためのセットアップ、エンティティマッピング、およびベストプラクティスをカバーしています。[159文字]

この記事では、Javaプロジェクト管理、自動化の構築、依存関係の解像度にMavenとGradleを使用して、アプローチと最適化戦略を比較して説明します。

この記事では、MavenやGradleなどのツールを使用して、適切なバージョン化と依存関係管理を使用して、カスタムJavaライブラリ(JARファイル)の作成と使用について説明します。
