首頁  >  文章  >  後端開發  >  如何在 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