Heim >Backend-Entwicklung >C++ >Wie konvertiert man Float in String mit in C angegebenen Genauigkeits- und Dezimalstellen?
Float in String mit angegebener Präzision und Dezimalstellen konvertieren
Konvertieren eines Floats in einen String in C unter Angabe der Genauigkeit und Anzahl der Dezimalstellen Ziffern sind häufig zum Formatieren numerischer Daten erforderlich.
Ein gängiger Ansatz ist die Verwendung von 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();
Der feste Manipulator gewährleistet die Festkomma-Notation, während setprecision( 2) beschränkt den Dezimalteil auf zwei Ziffern.
C 17 führte die Funktion to_chars für technische Konvertierungen ein:
<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>
Denken Sie daran, die Compiler-Konformität sicherzustellen, wenn Sie to_chars verwenden.
Das obige ist der detaillierte Inhalt vonWie konvertiert man Float in String mit in C angegebenen Genauigkeits- und Dezimalstellen?. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!