She*_*ohn 8 c++ numeric-limits
当我运行此代码时:
#include <limits>
#include <cstdio>
#define T double
int main()
{
static const T val = std::numeric_limits<T>::min();
printf( "%g/2 = %g\n", val, val/2 );
}
Run Code Online (Sandbox Code Playgroud)
我希望看到一个不可预测的结果.但我得到了正确的答案:
(16:53) > clang++ test_division.cpp -o test_division
(16:54) > ./test_division
2.22507e-308/2 = 1.11254e-308
Run Code Online (Sandbox Code Playgroud)
这怎么可能?
历史原因. std::numeric_limits最初是围绕<limits.h>(你有的地方
INT_MIN)和<float.h>(你有的地方DBL_MIN)的内容建立的.这两个文件(我怀疑)是由不同的人设计的; 做浮点运算的人不需要单独的最正和最负值,因为最负的总是否定最正,但他们确实需要知道大于0的最小值.遗憾的是,值具有相同的值名称的模式,std::numeric_limits最终min根据不同的方式定义不同
的语义std::numeric_limits<>::is_integer.
这使得模板编程更加笨拙,你不得不做std::numeric_limits<T>::is_integer ? std::numeric_limits<T>::min() : -std::numeric_limits<T>::max()
C++ 11添加的事情std::numeric_limits<>::lowest(),这完全符合你的期望.