Go での複数レベルの抽象化階層でのエラーの処理
Go では、複数レベルの抽象化を扱う場合、エラー処理が重要になります。クリーンで保守しやすいコードベースを維持するため。エラー メッセージの重複を防ぎ、エラーが意味のある方法で処理されるようにすることが重要です。
エラーをラップする
推奨されるアプローチは、エラー パッケージなどを使用してエラーをラップすることです。ツール。この手法では、元のエラーをラップする新しいエラー値を作成し、抽象化階層の各レベルでコンテキストを提供します。
エラーの注釈の例
次の例を使用して考えてみましょう。エラー パッケージ:
func (o *ObjectOne) CheckValue() error { if o.someValue == 0 { return errors.New("Object1 illegal state: value is 0") } return nil } func (oT *ObjectTwoHigherLevel) CheckObjectOneIsReady() error { if err := oT.objectOne.CheckValue(); err != nil { return errors.Wrap(err, "Object2 illegal state: Object1 is invalid") } return nil } func (oTh *ObjectThreeHiggerLevel) CheckObjectTwoIsReady() error { if err := oTh.ObjectTwoHigherLevel.CheckObjectOneIsReady(); err != nil { return errors.Wrap(err, "Object3 illegal state: Object2 is invalid") } return nil }
この例では、エラーは各レベルでラップされ、先頭のコンテキストの明確な痕跡が提供されます。
fmt.Errorf() Extension
エラーをラップする代わりに、fmt.Errorf を使用してエラーを拡張することもできます。 ()。このアプローチは簡単ですが、元のエラーを抽出することはできません。
func (o *ObjectOne) CheckValue() error { if o.someValue == 0 { return fmt.Errorf("Object1 illegal state: value is %d", o.someValue) } return nil } func (oT *ObjectTwoHigherLevel) CheckObjectOneIsReady() error { if err := oT.objectOne.CheckValue(); err != nil { return fmt.Errorf("Object2 illegal state: %v", err) } return nil } func (oTh *ObjectThreeHiggerLevel) CheckObjectTwoIsReady() error { if err := oTh.ObjectTwoHigherLevel.CheckObjectOneIsReady(); err != nil { return fmt.Errorf("Object3 illegal state: %v", err) } return nil }
エラー処理と委任
エラーを処理する必要があるかどうかを考慮することが重要です。より高いレベルに処理または委任されます。エラーの処理には、エラーの検査と特定のアクションの実行が含まれますが、委任によって責任が呼び出し元に渡されます。呼び出し元がエラーを処理する能力を備えている場合、またはエラーが単なる情報提供である場合は、委任が推奨されます。
エラー メッセージをログに記録する
エラー メッセージをログに記録するときは、次のことを確認してください。エラーとそのコンテキストについて十分な詳細を提供してください。エラーのエラー文字列と利用可能な追加情報を使用して、問題の根本原因を明確に特定します。
以上がGo のマルチレベル抽象化階層におけるエラーを効果的に処理するにはどうすればよいですか?の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。