首页 >后端开发 >C++ >在 C 中如何将浮点数转换为具有精度和小数位数的字符串?

在 C 中如何将浮点数转换为具有精度和小数位数的字符串?

DDD
DDD原创
2024-10-24 06:47:02251浏览

How Do You Convert a Float to a String with Precision and Number of Decimal Digits in C  ?

如何在 C 中将浮点数转换为具有精度和小数位数的字符串

在 C 中,您可以将浮点数转换为一个字符串,同时使用各种方法指定精度和小数位数,包括:

使用 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 确保固定-点表示法,std::set precision 设置小数位数。

使用 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指定定点表示法,第三个参数控制小数位数。

以上是在 C 中如何将浮点数转换为具有精度和小数位数的字符串?的详细内容。更多信息请关注PHP中文网其他相关文章!

声明:
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn