在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中文網其他相關文章!