目次
質問の内容
ホームページ バックエンド開発 Golang strconv.Parse* 関数から返されるエラーは、不正な入力データが原因であると考えても問題ありませんか?

strconv.Parse* 関数から返されるエラーは、不正な入力データが原因であると考えても問題ありませんか?

Feb 15, 2024 am 11:30 AM
標準ライブラリ

可以安全地假设从 strconv.Parse* 函数返回的任何错误一定是由于错误的输入数据造成的吗?

strconv.Parse 関数から返されるエラーは、不正な入力データが原因であると考えても問題ありませんか?この質問には、strconv.Parse 関数のエラー処理の理解が含まれます。通常、strconv.Parse 関数によって返されるエラーは、入力データが予期された形式ではないことが原因で発生します。ただし、考慮する必要がある特殊な状況がいくつかあります。一部のエラーは、文字列を整数に変換し、その文字列に数値以外の文字が含まれている場合など、入力データのタイプが間違っていることが原因である可能性があります。さらに、整数のオーバーフローや浮動小数点精度の損失などの特殊なケースがあり、これも誤った戻り値を引き起こす可能性があります。したがって、strconv.Parse 関数から返されたエラーについては、誤った入力データが原因であると完全に想定することはできませんが、考えられる他の要因を考慮する必要があります。

質問の内容

最近のコード レビュー中に、レビュー担当者から、strconv.ParseUint() から返されたエラーの処理方法について質問がありました。この関数は、変換された uint 値と *strconv.NumError 特定の種類のエラーを返すように文書化されています。ドキュメントには、このタイプの 2 つのセンチネル エラーが返される可能性があることが記載されています (ErrSyntaxErrRange)。どちらも不正なデータが提供されたことを意味します。関数のインターフェイスによっては、他のエラーが発生する場合もあります。

私のユースケースでは、手持ちの文字列値が uint に変換する価値があるかどうかを知る必要があります。 ParseUint がエラーを返し、それがセンチネル エラーの 1 つである場合、答えは見つかります。ただし、返されたエラーがこれらのいずれでもない場合は、エラーを返し、実行を停止します。私の査読者は、ParseUint から返された エラーは、間違ったデータを与えたことを意味すると考えるべきであり、センチネル エラーをチェックする必要はなく、センチネルをチェックする理由はない、と主張しました。エラーも返されません (私の使用例では)。これらは、ParseUint からのエラーが不正な入力データのチェックとして扱われ、返されない go 標準ライブラリの例にリンクしており、そのような例はたくさんあると述べています。

良好なデータと十分なリソースがあれば、常に望ましい結果を計算できるアルゴリズムが必要であることは確かに理解できますが、現実の世界は理論上の理想と常に一致するとは限りません。ライブラリのドキュメントには、不正なデータ以外の理由でエラーを返さない、または決してエラーを返さないと述べたものは見つかりません。標準ライブラリには、この例が 1 つ、またはおそらく多数あります。これは、一方では安心させるものですが、他方では恐ろしいことであり、「2 つの間違いが正しいことにはならない」と「彼らはこのようにしているので、そうしなければならない」の間のどこかにあります。この場合も同じことが行われます。

これは単にライブラリのドキュメントに一文が欠けているだけなのでしょうか?それとも、これら 2 つのエラーのどちらでもない場合にエラーを返すのが良いのでしょうか?どのように推論すればよいでしょうか?

解決策

はい、

strconv.ParseXXX関数のエラーは入力データが正しくないことが原因であると考えて間違いありません。

あなたが言及したドキュメントページから:

これを読むと、「strconv.ParseXXX のエラーは

NumError であり、無効な数値またはビット サイズ範囲エラーが原因である可能性があります。」となります。私の理解では、godoc は関数呼び出しの予想範囲を可能な限り完全に概説しようとしています。

したがって、これらは、

strconv.ParseXXX 関数から返される可能性のある のみの エラーであると想定しても問題ないと思います。何か他のものが戻ってきたら、それはドキュメントのバグだと考えます。

最後の質問に答えると、標準ライブラリからこの関数を呼び出したときに観察したパターンは正しいです。エラー全体を返し、それをどう処理するかを呼び出し側に決定させます。 Sentinel エラーは、何が問題になったのかを理解し、これらの関数で発生する可能性のある全範囲のエラーを表すのに役立つように設計されています。

以上がstrconv.Parse* 関数から返されるエラーは、不正な入力データが原因であると考えても問題ありませんか?の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

このウェブサイトの声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。

ホットAIツール

Undresser.AI Undress

Undresser.AI Undress

リアルなヌード写真を作成する AI 搭載アプリ

AI Clothes Remover

AI Clothes Remover

写真から衣服を削除するオンライン AI ツール。

Undress AI Tool

Undress AI Tool

脱衣画像を無料で

Clothoff.io

Clothoff.io

AI衣類リムーバー

Video Face Swap

Video Face Swap

完全無料の AI 顔交換ツールを使用して、あらゆるビデオの顔を簡単に交換できます。

ホットツール

メモ帳++7.3.1

メモ帳++7.3.1

使いやすく無料のコードエディター

SublimeText3 中国語版

SublimeText3 中国語版

中国語版、とても使いやすい

ゼンドスタジオ 13.0.1

ゼンドスタジオ 13.0.1

強力な PHP 統合開発環境

ドリームウィーバー CS6

ドリームウィーバー CS6

ビジュアル Web 開発ツール

SublimeText3 Mac版

SublimeText3 Mac版

神レベルのコード編集ソフト(SublimeText3)

C++で絶対値を使用する方法 C++で絶対値を使用する方法 May 06, 2024 pm 06:15 PM

C++ で絶対値を取得するには、次の 2 つの方法があります。 1. 組み込み関数 abs() を使用して、整数または浮動小数点型の絶対値を取得します。 2. 汎用関数 std::abs() を使用して、サポートされているさまざまな絶対値を取得します。データ型の絶対値を操作します。

_C言語での複雑な使い方 _C言語での複雑な使い方 May 08, 2024 pm 01:27 PM

複素数型は、C 言語で実数部と虚数部を含む複素数を表すために使用されます。その初期化形式は complex_number = 3.14 + 2.71i で、実数部は creal(complex_number) を通じてアクセスでき、虚数部は cimag(complex_number) を通じてアクセスできます。この型は、加算、減算、乗算、除算、剰余などの一般的な数学演算をサポートします。さらに、cpow、csqrt、cexp、csin など、複素数を処理するための一連の関数が提供されています。

C++でプライムは何を意味しますか C++でプライムは何を意味しますか May 07, 2024 pm 11:33 PM

prime は C++ のキーワードで、1 とそれ自体でしか割り切れない素数の型を示し、指定された値が素数であるかどうかを示すブール型として使用されます。 true、それ以外の場合は false。

C++ で std:: を使用する方法 C++ で std:: を使用する方法 May 09, 2024 am 03:45 AM

std は、標準ライブラリのコンポーネントを含む C++ の名前空間です。 std を使用するには、「using namespace std;」ステートメントを使用します。 std 名前空間からシンボルを直接使用するとコードを簡素化できますが、名前空間の汚染を避けるために必要な場合にのみお勧めします。

C++ におけるファブとは何を意味しますか C++ におけるファブとは何を意味しますか May 08, 2024 am 01:15 AM

fabs() 関数は、浮動小数点数の絶対値を計算し、負の符号を削除して正の値を返す C++ の数学関数です。浮動小数点パラメータを受け入れ、double 型の絶対値を返します。たとえば、fabs(-5.5) は 5.5 を返します。この関数は浮動小数点数を処理しますが、その精度は基盤となるハードウェアによって影響を受けます。

Javaのconfigってどういう意味ですか? Javaのconfigってどういう意味ですか? May 07, 2024 am 02:39 AM

Config は Java の構成情報を表し、通常は外部ファイルまたはデータベースに保存され、Java プロパティ、PropertyResourceBundle、Java 構成フレームワーク、またはサードパーティ ライブラリを通じて管理できます。その利点には、分離と柔軟性が含まれます。環境意識、管理性、拡張性。

C++で絶対値を計算する方法 C++で絶対値を計算する方法 May 06, 2024 pm 06:21 PM

C++ で絶対値を求める方法は 3 つあります。 abs() 関数を使用すると、あらゆるタイプの数値の絶対値を計算できます。 std::abs() 関数を使用すると、整数、浮動小数点数、および複素数の絶対値を計算できます。絶対値の手動計算。単純な整数に適しています。

C++でminは何を意味しますか C++でminは何を意味しますか May 08, 2024 am 12:51 AM

C++ の min 関数は、複数の値の最小値を返します。構文は次のとおりです: min(a, b)、a と b は比較される値です。 < 演算子をサポートしない型をサポートする比較関数を指定することもできます。 C++20 では、3 つ以上の最小値を処理する std::clamp 関数が導入されました。

See all articles