Каково точное значение numeric_limits:: digits10? Некоторые другие связанные вопросы в stackoverflow заставляли меня думать, что это максимальная точность двойника, но
- Следующий прототип начинает работать (sucess is true), когда точность больше, чем 17 (== 2 + numeric_limits:: digits10)
- С STLPort, readDouble == бесконечность в конце; с microsoft STL, readDouble == 0.0.
- Имеет ли этот прототип какой-либо смысл:)?
Вот прототип:
#include <float.h>
#include <limits>
#include <math.h>
#include <iostream>
#include <iomanip>
#include <sstream>
#include <string>
int main(int argc, const char* argv[]) {
std::ostringstream os;
//int digit10=std::numeric_limits<double>::digits10; // ==15
//int digit=std::numeric_limits<double>::digits; // ==53
os << std::setprecision(17);
os << DBL_MAX;
std::cout << os.str();
std::stringbuf sb(os.str());
std::istream is(&sb);
double readDouble=0.0;
is >> readDouble;
bool success = fabs(DBL_MAX-readDouble)<0.1;
}