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<iostream>
#include<string>
using namespace std;
int main()
{
//传统C语言的数值极限
cout<<"int:MAX() "<<INT_MAX<<endl;
cout<<"int:MIN() "<<INT_MIN<<endl;
cout<<"float:MAX() "<<FLT_MAX<<endl;
cout<<"float:MIN() "<<FLT_MIN<<endl;
cout<<"double:MAX() "<<DBL_MAX<<endl;
cout<<"double:MIN() "<<DBL_MIN<<endl;
cout<<"short:MAX() "<<SHRT_MAX<<endl;
cout<<"short:MIN() "<<SHRT_MIN<<endl; //採用模版类numeric_limits<>的方式获取极值
cout<<"int:MAX() "<<numeric_limits<int>::max()<<endl;
cout<<"int:MIN() "<<numeric_limits<int>::min()<<endl;
cout<<"float:MAX() "<<numeric_limits<float>::max()<<endl;
cout<<"float:MIN() "<<numeric_limits<float>::min()<<endl;
cout<<"double:MAX() "<<numeric_limits<double>::max()<<endl;
cout<<"double:MIN() "<<numeric_limits<double>::min()<<endl;
cout<<"short:MAX() "<<numeric_limits<short>::max()<<endl;
cout<<"short:MIN() "<<numeric_limits<short>::min()<<endl; //推断是否存在极值
cout<<"string类型是否存在极值:"<<numeric_limits<string>::is_specialized<<endl;
} //输出结果例如以下:
int:MAX() 2147483647
int:MIN() -2147483648
float:MAX() 3.40282e+038
float:MIN() 1.17549e-038
double:MAX() 1.79769e+308
double:MIN() 2.22507e-308
short:MAX() 32767
short:MIN() -32768
int:MAX() 2147483647
int:MIN() -2147483648
float:MAX() 3.40282e+038
float:MIN() 1.17549e-038
double:MAX() 1.79769e+308
double:MIN() 2.22507e-308
short:MAX() 32767
short:MIN() -32768
string类型是否存在极值:0
请按随意键继续. . .

简评:做为拥有优秀代码风格的程序猿来说最好的选择方式应该还是用标准库的template numeric_limits<>会比較好,详细的理由是:一、相比C语言的提前定义常数标准库的numeric_limits提供了更好的安全性。二、numeric_limits<>类能够说是一个各种类型信息的模版体系,更加规范,并且更重要的是程序猿自己也能够通过为template
numeric_limits添加特化版本号而你自己定义的数值类型添加类型信息。从而在编程时能够达到统一规范调用的效果。

C++数值类型极限值的获取的更多相关文章

  1. DataRow获取数值类型为空或NULL时异常处理

    //获取数据集内容 DataSet ContractDS = dal.GetJHFKStr(jhfubh); //验证数据集是否为空 if (!DataSetUtil.IsNullOrEmpty(Co ...

  2. Python黑帽编程2.2 数值类型

    Python黑帽编程2.2  数值类型 数值类型,说白了就是处理各种各样的数字,Python中的数值类型包括整型.长整型.布尔.双精度浮点.十进制浮点和复数,这些类型在很多方面与传统的C类型有很大的区 ...

  3. .Net判断一个对象是否为数值类型探讨总结(高营养含量,含最终代码及跑分)

    前一篇发出来后引发了积极的探讨,起到了抛砖引玉效果,感谢大家参与. 吐槽一下:这个问题比其看起来要难得多得多啊. 大家的讨论最终还是没有一个完全正确的答案,不过我根据讨论结果总结了一个差不多算是最终版 ...

  4. .Net判断一个对象是否为数值类型

    这乍一听是个很简单的事,但突然搞起来还真有点无从下手的感觉. 首先当然是通过GetType()方法反射获取其类型信息,然后对其进行分析,但是类型信息Type中并没有简单地给出这么一个属性进行判断. 老 ...

  5. POI使用:用poi接口不区分xls/xlsx格式解析Excel文档(41种日期格式解析方法,5种公式结果类型解析方法,3种常用数值类型精度控制办法)

    一.使用poi解析excel文档 注:全部采用poi接口进行解析,不需要区分xls.xlsx格式,不需要判断文档类型. poi中的日期格式判断仅支持欧美日期习惯,对国内的日期格式并不支持判断,怎么办? ...

  6. C++数值类型与string的相互转换

    转自:https://www.cnblogs.com/johngu/p/7878029.html 1.数值类型转换为string 1.1使用函数模板+ostringstream 使用函数模板将基本数据 ...

  7. C++.【转】C++数值类型与string的相互转换

    1.C++数值类型与string的相互转换 - JohnGu - 博客园.html(https://www.cnblogs.com/johngu/p/7878029.html) 2. 1.数值类型转换 ...

  8. ECharts的x轴和y轴均使用数值类型

    今天有个需求,就是需要ECharts的x轴和y轴都要使用数值类型,即xAxis.type和yAxis.type均为value,然后我按照我以为的方式修改了下,发现图崩了 发现问题: 然后我打开了ECh ...

  9. MyBatis 数值类型 where 条件配置的坑

    复现异常 我们先通过案例复现该类异常,测试项目地址:https://gitee.com/yin_jw/demo/tree/master/mybatis-demo/springboot-mybatis- ...

随机推荐

  1. ES6和Node容易搞混淆的点

    ES6 import  模块名 from XX  '模块标识符'     -----导入模块 import '路径 ' -----导入CSS样式 export default { }  和export ...

  2. 在树莓派下对多个串口转USB设备进行设备名称绑定操作

    在开发过程中,需要用一个树莓派链接多个串口转USB设备(GPS模块,数传模块等),在树莓派linux系统环境下,USB串口设备的命名规则是 /dev/ttyUSB0 ,/dev/ttyUSB1,/de ...

  3. 如何删除github wiki page

    title: 如何删除github wiki page toc: false date: 2019-02-23 10:08:41 categories: methods tags: github wi ...

  4. Java中的命名规范到底是怎样的

    内容摘要:命名规范二,java中的方法名,对象名和字段名的第一个单词的首写字母应该小写,而后面的每个单词的首字母都应该小写 要想将java基础学的十分的牢固就必须将java中的命名规范掌握好了.俗话说 ...

  5. 在Mac OSX上安装ffmpeg && ffmpeg命令行将h264封装为mp4

    ffmpeg功能强大,可以通过命令行来对音视频进行处理.为了使用其功能,我在Mac上对其进行了安装. 我的Mac OS X 系统版本:OS X Yosemite, 10.10.14 关于ffmpeg在 ...

  6. zgb老师关于java集合的总结

    数组:存多个数据 操作不便集合(Collection ):存多个数据 管理多个数据 提供更为方便的操作Iterator:专门针对集合 进行迭代List:有序的 允许重复的元素ArrayList:底层数 ...

  7. javascript 将单词首字母大写,其余小写

    // 1 别人写的,我拿来参考了一下 function titleCase(str) { var array = str.toLowerCase().split(" "); for ...

  8. 第八周读书笔记(人月神话X月亮与六便士)——到底什么才是一个程序员的自我修养?

    写了这么久的读书笔记,涉及到问题大多是一些如何把软件工程做好,如何把自己的职业生涯做好.但总感觉逻辑链上缺了一环,亦即:我们为什么要把软件工程做好,我们成为一名优秀的职业生涯的意义到底在于什么?我觉得 ...

  9. 时空上下文视觉跟踪(STC)

    论文的关键点是对时空上下文(Spatio-Temporal Context)信息的利用.主要思想是通过贝叶斯框架对要跟踪的目标和它的局部上下文区域的时空关系进行建模,得到目标和其周围区域低级特征的统计 ...

  10. Linux VFS分析(二)

    inode的管理:Inode-cache hash表inode_hashtable索引节点缓存 dentry的管理: 我们知道,若干dentry描绘了一个树型的目录结构,这就是用户所看到的目录结构,每 ...