Golang でのエラー処理: エラーの非表示を避ける
はじめに:
エラーは、プログラミング プロセスでよく遭遇する問題の 1 つです。エラー処理方法が正しいかどうかは、プログラムの信頼性と安定性に直接影響します。 Golang では、特に外部インターフェイスを呼び出したり、複雑なロジックを処理する必要があるプログラムを作成する場合、エラー処理は重要なタスクです。この記事では、隠れたエラーを回避し、プログラムをより堅牢にする方法に焦点を当てます。
Golang では、エラー タイプをカスタマイズできます。エラー タイプを定義するときは、通常、error
インターフェイスの要件を満たす必要があります。つまり、そのタイプは Error() string
メソッドを実装する必要があります。このようにして、実際のビジネス ニーズに基づいてさまざまなエラー タイプを定義できます。
以下は、カスタム エラー タイプを定義する簡単な例です。MyError
:
type MyError struct { Msg string // 错误信息 Code int // 错误码 } func (e *MyError) Error() string { return fmt.Sprintf("Error: %s, Code: %d", e.Msg, e.Code) }
コード内でこのエラー タイプを使用して、特定のエラーを表すことができます。たとえば、関数の戻り結果の処理中にエラーが発生した場合、MyError
タイプのエラーが返されます。
func doSomething() error { // 执行一些操作,可能会发生错误 // 如果发生错误,返回一个 MyError return &MyError{ Msg: "Something went wrong", Code: 500, } }
この関数を呼び出すと、if
ステートメントを使用してエラーが発生したかどうかを判断できます。エラーが発生した場合、型アサーションを通じて特定のエラー情報を取得できます。
err := doSomething() if err != nil { if myErr, ok := err.(*MyError); ok { fmt.Printf("Error: %s, Code: %d ", myErr.Msg, myErr.Code) } else { fmt.Println(err) } }
Golang では、errors
パッケージで提供される New()## を使用できます。 # 単純なエラーを作成する関数。
err := errors.New("Something went wrong")
Wrap() 関数を使用して、追加のコンテキスト情報を追加しながら、このエラーを新しいエラーにラップできます。
err = errors.Wrap(err, "Failed to do something")
func doSomething() error { err := doSomethingElse() if err != nil { return errors.Wrap(err, "Failed to do something") } return nil } func doSomethingElse() error { // 执行一些操作,可能会发生错误 // 如果发生错误,返回一个简单的错误 return errors.New("Something went wrong") }
Cause() 関数を使用して最初に発生したエラーを取得できるため、さまざまな種類のエラーを処理できます。
err := doSomething() if err != nil { rootErr := errors.Cause(err) if myErr, ok := rootErr.(*MyError); ok { fmt.Printf("Error: %s, Code: %d ", myErr.Msg, myErr.Code) } else { fmt.Println(err) } }
Golang では、エラー処理は重要なタスクです。エラー タイプを定義して使用し、エラー処理の呼び出しを連鎖することにより、隠れたエラーをより適切に回避し、プログラムをより堅牢で信頼性の高いものにすることができます。同時に、適切なエラー処理の習慣により、コードの保守性と可読性が向上し、その後のメンテナンスとアップグレードが容易になります。
以上がGolang でのエラー処理: エラーの非表示を避けるの詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。