动机
我们在平时的程序开发和测试的过程中有时候需要取得特定平台特定算术数据类型的范围,如在32位平台上unsigned int的最大值(65535)和最小值(0),一般来讲,我们很难去刻意去记住这些数值,比如int类型。C++标准模板库给我们提供了一个简单的方法供我们调用,即numeric_limits。
用途
numeric_limits模板类为获取算术类型特性提供了一种标准的方法。如std::numeric_limits<int>::max()
定义
官方关于numeric_limits的文档:numeric_limits reference
template<class T>
class numeric_limits;
上述模板是numeric_limits的基础模板,标准库针对每一种特定的算术类型对基础模板做了特化(关于模板的特化概念读者自行搜索),如下所示:
template<> class numeric_limits<bool>;
template<> class numeric_limits<char>;
template<> class numeric_limits<signed char>;
template<> class numeric_limits<unsigned char>;
template<> class numeric_limits<wchar_t>;
template<> class numeric_limits<char16_t>; // C++11 feature
template<> class numeric_limits<char32_t>; // C++11 feature
template<> class numeric_limits<short>;
template<> class numeric_limits<unsigned short>;
template<> class numeric_limits<int>;
template<> class numeric_limits<unsigned int>;
template<> class numeric_limits<long>;
template<> class numeric_limits<unsigned long>;
template<> class numeric_limits<long long>;
template<> class numeric_limits<unsigned long long>;
template<> class numeric_limits<float>;
template<> class numeric_limits<double>;
template<> class numeric_limits<long double>;
使用
使用前需要包含头文件<limits>
,以下是使用的例子:
#include <iostream>
#include <limits>
int main(int argc, char argv[])
{
std::cout << "int min : " << std::numeric_limits<int>::min() << std::endl;
std::cout << "int max : " << std::numeric_limits<int>::max() << std::endl;
std::cout << "float min : " << std::numeric_limits<float>::min() << std::endl;
std::cout << "float max : " << std::numeric_limits<float>::max() << std::endl;
return 0;
}
程序输出如下:
int min : -2147483648
int max : 2147483647
float min : 1.17549e-38
float max : 3.40282e+38
总结
- numeric_limits为我们提供了一种去获取算术类型信息的标准方法
- 在使用时要包含
<limits>头文件