C で精度と小数点以下の桁数を指定して float を文字列に変換する方法
C では、float を次のように変換できます。
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();
このアプローチでは、std::fixed により、精度と 10 進数の桁数を指定します。 -point 表記、std::setprecision は小数点以下の桁数を設定します。
std::to_chars の使用 (C 17)
特定の技術的な変換については、C 17 std::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 は固定小数点表記を指定し、3 番目のパラメーターは小数点以下の桁数を制御します。
以上がC で浮動小数点数を精度と小数点以下の桁数で文字列に変換するにはどうすればよいですか?の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。