在C++中,<limits>
头文件定义了一系列模板类和静态常量,用于表示各种数据类型的属性,如最小值、最大值、精度等
std::numeric_limits<T>::min()
:返回类型T的最小值。对于整数类型,这通常是负的最大值,对于无符号整数类型,这是0。对于浮点类型,这是正的最小规范化值。std::numeric_limits<T>::max()
:返回类型T的最大值。对于整数类型,这是正的最大值,对于浮点类型,这是正的最大规范化值。std::numeric_limits<T>::lowest()
:返回类型T的最低可能值。对于浮点类型,这是负的最大规范化值。对于整数类型,这与min()
相同。std::numeric_limits<T>::epsilon()
:返回类型T的机器精度。这是1.0与大于1.0的最小可表示浮点数之间的差值。对于整数类型,这是0。std::numeric_limits<T>::digits
:返回类型T的基数为底的位数。对于整数类型,这是二进制位数。对于浮点类型,这是有效数字位数。std::numeric_limits<T>::digits10
:返回类型T的十进制位数。这是可以表示的最大十进制数字位数。std::numeric_limits<T>::is_signed
:如果类型T是有符号的,则为true。std::numeric_limits<T>::is_integer
:如果类型T是整数类型,则为true。std::numeric_limits<T>::is_exact
:如果类型T的算术运算是精确的,则为true。对于浮点类型,这是false。std::numeric_limits<T>::radix
:返回类型T的基数。对于整数类型,这是2(二进制)。对于浮点类型,这是基数为FLT_RADIX的浮点数。下面是一个简单的示例,展示了如何使用<limits>
头文件来获取不同数据类型的属性:
#include<iostream>
#include<limits>
int main() {
std::cout << "int min: "<< std::numeric_limits<int>::min()<< std::endl;
std::cout << "int max: "<< std::numeric_limits<int>::max()<< std::endl;
std::cout << "unsigned int max: "<< std::numeric_limits<unsigned 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;
std::cout << "float epsilon: "<< std::numeric_limits<float>::epsilon()<< std::endl;
std::cout << "double min: "<< std::numeric_limits<double>::min()<< std::endl;
std::cout << "double max: "<< std::numeric_limits<double>::max()<< std::endl;
std::cout << "double epsilon: "<< std::numeric_limits<double>::epsilon()<< std::endl;
return 0;
}
这将输出各种数据类型的最小值、最大值、精度等信息。