首页  >  文章  >  后端开发  >  如何在 C 中控制浮点到字符串的转换精度和小数位数?

如何在 C 中控制浮点到字符串的转换精度和小数位数?

Barbara Streisand
Barbara Streisand原创
2024-10-24 06:08:02134浏览

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

修改 C 中浮点到字符串的转换精度和小数位数

在 C 中将浮点转换为字符串时,通常需要控制精度和小数位显示的小数位数。下面是如何实现这一点:

使用字符串流

常见的方法是使用字符串流:

<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();

fixed 标志确保定点表示法是使用,而 set precision(2) 指定仅应显示两位小数。

技术目的转换

出于技术目的,例如以 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 指定小数位数。

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

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