Go の遅延関数におけるパニック処理
Go におけるパニック処理は、エラー管理の重要な側面です。 C ではデストラクターからパニックを起こすことは一般に推奨されませんが、Go では遅延関数内からパニックを起こすことは安全で許容されます。
パニック伝播と上書き
提供されたコード例:
<br>func sub(){</p> <pre class="brush:php;toolbar:false">defer func (){ panic(2) }() panic(1)
}
func main(){
defer func(){ x:=recover() println(x.(int)); }() sub()
}
2 番目の Panic(2) は最初の Panic(1) を上書きしません。代わりに、両方のパニックが main 関数に伝播され、そこで遅延回復関数が最初の Panic(1) から値を取得して出力します。
Panic Termination and Recovery
遅延関数内でパニックが発生すると、パニック シーケンスが継続します。ただし、遅延関数が (recover() 関数を使用して) パニックから回復すると、パニック シーケンスは停止します。これにより、パニックによって Go プログラムが途中で終了することがなくなります。
例: 複数の遅延パニックとリカバリ
次の例に示すように:
<br>func main() {</p> <pre class="brush:php;toolbar:false">defer func() { fmt.Println("Checkpoint 1") panic(1) }() defer func() { fmt.Println("Checkpoint 2") panic(2) }() panic(999)
}
すべての遅延関数が Panic() を実行しても、次の変更例で明らかなように、任意の遅延関数:
<br>defer func() {</p> <pre class="brush:php;toolbar:false">recover() fmt.Println("Checkpoint 1") panic(1)
}()
defer func() {
recover() fmt.Println("Checkpoint 2") panic(2)
}()
この場合、最後のパニック シーケンスにはすべてのパニック値に関する情報が含まれ、リカバリが発生した場所が示されます。
結論
Go の遅延関数でのパニック処理は柔軟性を提供し、パニック シーケンスの継続を可能にします。遅延パニックから回復する機能により、パニックによってプログラムが途中で終了することがなくなります。 Go プログラマーは、このメカニズムを利用して、堅牢なエラー処理戦略を実装できます。
以上がGo の遅延関数でパニックはどのように動作しますか?の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。