ホームページ  >  記事  >  バックエンド開発  >  C で浮動小数点から文字列への変換精度と 10 進数を制御するにはどうすればよいですか?

C で浮動小数点から文字列への変換精度と 10 進数を制御するにはどうすればよいですか?

Barbara Streisand
Barbara Streisandオリジナル
2024-10-24 06:08:02134ブラウズ

How to Control Float-to-String Conversion Precision and Decimal Digits in C  ?

C での浮動小数点から文字列への変換の精度と 10 進数の変更

C で浮動小数点を文字列に変換する場合、多くの場合、精度と小数点を制御する必要があります。表示される小数点以下の桁数。これを実現する方法は次のとおりです。

Stringstream の使用

一般的なアプローチは、stringstream を使用することです。

<code class="cpp">#include <iomanip>
#include <sstream>

double pi = 3.14159265359;
std::stringstream stream;
stream << std::fixed << std::setprecision(2) << pi;
std::string s = stream.str();

固定フラグにより​​、固定小数点表記が確実に行われます。

技術的な目的のための変換

XML または JSON でのデータの保存などの技術的な目的のために、C 17 では、 to_chars 関数ファミリー:

<code class="cpp">#include <array>
#include <charconv>

double pi = 3.14159265359;
std::array<char, 128> buffer;
auto [ptr, ec] = std::to_chars(buffer.data(), buffer.data() + buffer.size(), pi,
                               std::chars_format::fixed, 2);
if (ec == std::errc{}) {
    std::string s(buffer.data(), ptr);
    // ....
}
else {
    // error handling
}</code>

ここで、std::chars_format::fixed は固定小数点表記を保証し、2 は 10 進数の桁数を指定します。

以上がC で浮動小数点から文字列への変換精度と 10 進数を制御するにはどうすればよいですか?の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

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