C/C++中基本类型的数值极限值一般来说都是与详细平台有关的,在程序设计的过程中为了写出与平台无关的程序则必须通过合理科学的方法去获取各种类型的极值,经常使用的获取方法有两种:一种是传统的C语言所採用的预处理器常数。还有一种方法则是通过标准库中所提供的模版类numeric_limits<>来获取这些极值。
以下先具体解释其使用方法后再评其优劣:
一、传统C语言的预处理器常数
在C++中这些C语言的预处理器常数任然能够用,一般对于各种基本固有类型的最大值宏为:
INT_MAX、FLT_MAX、DBL_MAX、SHRT_MAX、CHAR_MAX. . . . .
分别相应int、float、double、short、char、、、的最大值,其它类型都有类似形式的宏
最小值宏为:
INT_MIN、FLT_MIN、DBL_MIN、SHRT_MIN、CHAR_MIN. . . . .
分别相应int、float、double、short、char、、、的最小值。其它类型都有类似形式的宏
二、标准库template numeric_limits<>
numeric_limits<>是一个模版类。它是有一个通用模版和一系列各种类型的特化模版组成。在该模版类中经常使用的几个数据成员和成员函数例如以下:
is_specialized 该类型是否存在极值
is_signed 该类型是否带有正负号
min() 获取最小值
max() 获取最大值
详细应用演示样例代码例如以下:
#include#include using namespace std;int main(){//传统C语言的数值极限 cout<<"int:MAX() "< < 的方式获取极值 cout<<"int:MAX() "< ::max()<