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

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

DDD
DDD原创
2024-10-24 06:37:30534浏览

How to Convert Float to String with Precision and Decimal Digits Specified in C  ?

将浮点数转换为指定精度和小数位的字符串

在指定精度和小数位数的情况下将浮点数转换为 C 中的字符串格式化数字数据通常需要数字。

一种常见的方法是利用 stringstream:

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

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

fixed 操纵器确保定点表示法,而 set precision( 2) 将小数部分限制为两位数。

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);
}</code>

使用 to_chars 时请记住确保编译器合规性。

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

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