¿Por qué std :: setprecision (6) transmite más de seis dígitos en modo de ancho fijo?
La salida del siguiente código:
#include <limits>
#include <iostream>
#include <iomanip>
#include <limits>
#include <string>
#include <sstream>
using namespace std;
inline string lexical_cast(const float arg)
{
stringstream ss;
ss << fixed << setprecision(numeric_limits<float>::digits10) << arg;
if (!ss)
throw "Conversion failed";
return ss.str();
}
int main()
{
cout << numeric_limits<float>::digits10 << '\n';
cout << lexical_cast(32.123456789) << '\n';
}
es:
6
32.123455
Esperaba y quería:
6
32.1234
porque, que yo sepa, ese es el alcance de lo quefloat
puede darme confiablemente en mi sistema.
¿Cómo puedo persuadir a IOStreams para que se comporte como quiero?