strconv.Parse* 関数から返されるエラーは、不正な入力データが原因であると考えても問題ありませんか?
strconv.Parse 関数から返されるエラーは、不正な入力データが原因であると考えても問題ありませんか?この質問には、strconv.Parse 関数のエラー処理の理解が含まれます。通常、strconv.Parse 関数によって返されるエラーは、入力データが予期された形式ではないことが原因で発生します。ただし、考慮する必要がある特殊な状況がいくつかあります。一部のエラーは、文字列を整数に変換し、その文字列に数値以外の文字が含まれている場合など、入力データのタイプが間違っていることが原因である可能性があります。さらに、整数のオーバーフローや浮動小数点精度の損失などの特殊なケースがあり、これも誤った戻り値を引き起こす可能性があります。したがって、strconv.Parse 関数から返されたエラーについては、誤った入力データが原因であると完全に想定することはできませんが、考えられる他の要因を考慮する必要があります。
質問の内容
最近のコード レビュー中に、レビュー担当者から、strconv.ParseUint()
から返されたエラーの処理方法について質問がありました。この関数は、変換された uint 値と *strconv.NumError
特定の種類のエラーを返すように文書化されています。ドキュメントには、このタイプの 2 つのセンチネル エラーが返される可能性があることが記載されています (ErrSyntax
と ErrRange
)。どちらも不正なデータが提供されたことを意味します。関数のインターフェイスによっては、他のエラーが発生する場合もあります。
私のユースケースでは、手持ちの文字列値が uint に変換する価値があるかどうかを知る必要があります。 ParseUint
がエラーを返し、それがセンチネル エラーの 1 つである場合、答えは見つかります。ただし、返されたエラーがこれらのいずれでもない場合は、エラーを返し、実行を停止します。私の査読者は、ParseUint
から返された エラーは、間違ったデータを与えたことを意味すると考えるべきであり、センチネル エラーをチェックする必要はなく、センチネルをチェックする理由はない、と主張しました。エラーも返されません (私の使用例では)。これらは、ParseUint からのエラーが不正な入力データのチェックとして扱われ、返されない go 標準ライブラリの例にリンクしており、そのような例はたくさんあると述べています。
これは単にライブラリのドキュメントに一文が欠けているだけなのでしょうか?それとも、これら 2 つのエラーのどちらでもない場合にエラーを返すのが良いのでしょうか?どのように推論すればよいでしょうか? 解決策はい、
strconv.ParseXXX関数のエラーは入力データが正しくないことが原因であると考えて間違いありません。
これを読むと、「strconv.ParseXXX のエラーは
NumError であり、無効な数値またはビット サイズ範囲エラーが原因である可能性があります。」となります。私の理解では、godoc は関数呼び出しの予想範囲を可能な限り完全に概説しようとしています。
strconv.ParseXXX 関数から返される可能性のある
のみの エラーであると想定しても問題ないと思います。何か他のものが戻ってきたら、それはドキュメントのバグだと考えます。
以上がstrconv.Parse* 関数から返されるエラーは、不正な入力データが原因であると考えても問題ありませんか?の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

ホットAIツール

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

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

Undress AI Tool
脱衣画像を無料で

Clothoff.io
AI衣類リムーバー

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

人気の記事

ホットツール

メモ帳++7.3.1
使いやすく無料のコードエディター

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

ゼンドスタジオ 13.0.1
強力な PHP 統合開発環境

ドリームウィーバー CS6
ビジュアル Web 開発ツール

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

ホットトピック









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

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

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

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

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

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

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

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