Por que std :: setprecision (6) transmite mais de seis dígitos no modo de largura fixa?
A saída do seguinte 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';
}
é:
6
32.123455
Eu esperava e queria:
6
32.1234
porque, até onde eu sei, essa é a extensão do quefloat
pode me dar com segurança no meu sistema.
Como convencer o IOStreams a se comportar como eu quero?