ホームページ >バックエンド開発 >C++ >C で文字列を倍精度数値に安全に変換するにはどうすればよいですか?

C で文字列を倍精度数値に安全に変換するにはどうすればよいですか?

Linda Hamilton
Linda Hamiltonオリジナル
2024-10-26 08:13:02887ブラウズ

How to Safely Convert Strings to Double Precision Numbers in C  ?

C で文字列を倍精度数値に変換する

C で文字列と数値データを扱う場合、多くの場合、文字列を倍精度浮動小数点数に変換する必要があります。この記事では、数値以外の文字列を適切に処理することに焦点を当てて、この問題の解決策を検討します。

関数

変換を実現するには、文字列参照を受け取る関数 string_to_double を定義します。を入力して double 値を返します。この関数内:

  • std::istringstream オブジェクトが入力文字列で初期化されます。
  • 結果を受け取るために double 変数 x が宣言されます。
  • isstringstream >>演算子は、ストリームから x 変数にデータを抽出するために使用されます。
  • 数値以外の文字が原因で抽出が失敗した場合、関数は 0.0 を返します。
  • それ以外の場合は、抽出された double 値が返されます。 .

使用法とテスト

提供されたサンプル コードでは、string_to_double がさまざまな文字列入力で呼び出され、その機能を示します。

  • 単純なケースは、予期される double 値です。
  • 先頭または末尾の空白は正しく処理されます。
  • 数字の後の非数字文字は無視されます。
  • 関数の制限は、すべての有効な値を区別できないことです。ゼロの文字列表現 (例: "0"、"0.0"、"0.0e0") および数値以外の文字列。

結論

string_to_double 関数は、シンプルで効率的な関数を提供します。 C で文字列を倍精度浮動小数点数に変換する方法。数値以外の文字列を処理することで、要件に従って、これらの場合に 0.0 が返されることが保証されます。

以上がC で文字列を倍精度数値に安全に変換するにはどうすればよいですか?の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

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