numeric_limits :: digit10的精确含义是什么? 计算器中的其他一些相关的问题,让我觉得这是一个双重的最大精度,但numeric_limits <double> :: digits10是什么意思
- 以下原型开始工作(sucess为true)时,精度大于17(= = 2 + numeric_limits :: digits10)
- 使用STLPort,readDouble == infinity结束;与微软的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;
}
相关:[花车分数精确度(HTTP:/ /stackoverflow.com/questions/3310276/decimal-precision-of-floats)和[是6还是7.22?](ht TP://stackoverflow.com/q/30688422/183120)。 – legends2k 2015-08-25 07:39:12