Java の Final ブロックでのフロー制御の物議を醸す実践
Return ステートメントやその他の形式のフロー制御を Java ブロック内に含めると広く信じられています。 Javaのfinallyブロックは疑わしいやり方です。しかし、この一般的な合意にもかかわらず、特定の状況ではその使用が正当化される場合があります。
説得力のある例の 1 つは、コードのより深いレベル内で例外が発生するが、上位に伝播する必要があるという状況から生じます。次のコード スニペットを考えてみましょう:
Object problemMethod() { Object rtn = null; try { rtn = somethingThatThrewAnException(); } finally { doSomeCleanup(); return rtn; } }
この例では、somethingThatThrewAnException メソッド内で発生したキャッチされなかった例外が再スローされています。ただし、finally ブロックの return ステートメントは例外伝播プロセスを途中で中止し、problemMethod の呼び出し元にプロセスが到達できなくなります。
このシナリオは、例外伝播を途中で終了する潜在的な危険性を浮き彫りにしています。技術的には、finally ブロックでフロー制御を使用することは許可されていますが、コードの読みやすさと保守性の観点から、使用は避けるべきです。例外は常に適切に処理および伝播される必要があり、この目的で Finally ブロックに依存すると、予期しない複雑な動作が発生する可能性があります。
以上がJava の Final ブロックでフロー制御を使用する必要がありますか?の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。