Heim >Backend-Entwicklung >C++ >Wie steuere ich die Genauigkeit der Float-zu-String-Konvertierung und die Dezimalstellen in C?
Beim Konvertieren einer Gleitkommazahl in eine Zeichenfolge in C ist es häufig erforderlich, die Präzision und zu steuern Anzahl der angezeigten Dezimalstellen. So kann dies erreicht werden:
Ein gängiger Ansatz ist die Verwendung eines Stringstreams:
<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();
Das Fixed-Flag stellt sicher, dass eine Festkomma-Notation vorliegt verwendet, während setprecision(2) angibt, dass nur zwei Dezimalstellen angezeigt werden sollen.
Für technische Zwecke, wie zum Beispiel das Speichern von Daten in XML oder JSON, führt C 17 das ein to_chars-Funktionsfamilie:
<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>
Hier gewährleistet std::chars_format::fixed die Festkommaschreibweise und 2 gibt die Anzahl der Dezimalstellen an.
Das obige ist der detaillierte Inhalt vonWie steuere ich die Genauigkeit der Float-zu-String-Konvertierung und die Dezimalstellen in C?. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!