カスタム エラー タイプで Go アプリケーションを強化すると、エラー処理が強化されますが、これらのカスタム タイプの操作は困難な場合があります。カスタム エラーの種類をチェックする問題を詳しく見てみましょう。
次のカスタム エラー タイプを考えてみましょう。
type ModelMissingError struct { msg string // description of error } func (e *ModelMissingError) Error() string { return e.msg }
メソッド内では、カスタム エラーをスローできます:
return Model{}, &ModelMissingError{"no model found for id"}
エラーが特定のカスタム タイプであるかどうかを判断するには、そのタイプを確認する必要があります。ただし、このアプローチ if err == model.ModelMissingError は失敗します。
Go は、型アサーションをチェックするための カンマ OK イディオム を提供します。
serr, ok := err.(*model.ModelMissingError)
このステートメントは、エラー変数 err が model.ModelMissingError 型を保持し、基になる値を割り当てることをアサートします。変数serrに。 err が予期したタイプを保持しない場合、ステートメントは serr の場合は nil を返し、ok の場合は false を返します。
カンマ ok イディオムを使用することで、カスタム エラーのタイプを効率的に検証し、それに応じて処理できます。
以上がGo でカスタム エラーの種類を確認するにはどうすればよいですか?の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。