Maison >développement back-end >C++ >Comment contrôler la précision de la conversion float-to-string et les chiffres décimaux en C ?
Lors de la conversion d'un float en chaîne en C, il est souvent nécessaire de contrôler la précision et nombre de chiffres décimaux affichés. Voici comment cela peut être réalisé :
Une approche courante consiste à utiliser un stringstream :
<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();
L'indicateur fixe garantit qu'une notation à virgule fixe est utilisé, tandis que setprecision(2) spécifie que seuls deux chiffres décimaux doivent être affichés.
À des fins techniques, telles que le stockage de données au format XML ou JSON, C 17 introduit le Famille de fonctions 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>
Ici, std::chars_format::fixed garantit la notation à virgule fixe, et 2 spécifie le nombre de chiffres décimaux.
Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!