C++数值类型极限值的获取
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++数值类型极限值的获取的更多相关文章
- DataRow获取数值类型为空或NULL时异常处理
//获取数据集内容 DataSet ContractDS = dal.GetJHFKStr(jhfubh); //验证数据集是否为空 if (!DataSetUtil.IsNullOrEmpty(Co ...
- Python黑帽编程2.2 数值类型
Python黑帽编程2.2 数值类型 数值类型,说白了就是处理各种各样的数字,Python中的数值类型包括整型.长整型.布尔.双精度浮点.十进制浮点和复数,这些类型在很多方面与传统的C类型有很大的区 ...
- .Net判断一个对象是否为数值类型探讨总结(高营养含量,含最终代码及跑分)
前一篇发出来后引发了积极的探讨,起到了抛砖引玉效果,感谢大家参与. 吐槽一下:这个问题比其看起来要难得多得多啊. 大家的讨论最终还是没有一个完全正确的答案,不过我根据讨论结果总结了一个差不多算是最终版 ...
- .Net判断一个对象是否为数值类型
这乍一听是个很简单的事,但突然搞起来还真有点无从下手的感觉. 首先当然是通过GetType()方法反射获取其类型信息,然后对其进行分析,但是类型信息Type中并没有简单地给出这么一个属性进行判断. 老 ...
- POI使用:用poi接口不区分xls/xlsx格式解析Excel文档(41种日期格式解析方法,5种公式结果类型解析方法,3种常用数值类型精度控制办法)
一.使用poi解析excel文档 注:全部采用poi接口进行解析,不需要区分xls.xlsx格式,不需要判断文档类型. poi中的日期格式判断仅支持欧美日期习惯,对国内的日期格式并不支持判断,怎么办? ...
- C++数值类型与string的相互转换
转自:https://www.cnblogs.com/johngu/p/7878029.html 1.数值类型转换为string 1.1使用函数模板+ostringstream 使用函数模板将基本数据 ...
- C++.【转】C++数值类型与string的相互转换
1.C++数值类型与string的相互转换 - JohnGu - 博客园.html(https://www.cnblogs.com/johngu/p/7878029.html) 2. 1.数值类型转换 ...
- ECharts的x轴和y轴均使用数值类型
今天有个需求,就是需要ECharts的x轴和y轴都要使用数值类型,即xAxis.type和yAxis.type均为value,然后我按照我以为的方式修改了下,发现图崩了 发现问题: 然后我打开了ECh ...
- MyBatis 数值类型 where 条件配置的坑
复现异常 我们先通过案例复现该类异常,测试项目地址:https://gitee.com/yin_jw/demo/tree/master/mybatis-demo/springboot-mybatis- ...
随机推荐
- net快速写入/读取大量数据Postgresql
Postgresql快速写入/读取大量数据 http://www.cnblogs.com/podolski/p/7152144.html 环境及测试 使用.net驱动npgsql连接post数据库.配 ...
- html中常见的小问题(1)
问题:自适应高度的块级元素内添加图片后,其高度会比图片高度多出一块 简单代码如下: <!doctype html> <html> <head> <style& ...
- 微信小程序video组件出现无法播放或卡顿
微信小程序使用video组件播放视频的时候,会出现卡顿或者无法播放的问题,加一个custom-cache=”true“即可解决,这个属性文档上没有,是从小程序开发社区中get到的.
- 第九课: - 导出到CSV / EXCEL / TXT
第 9 课 将数据从microdost sql数据库导出到cvs,excel和txt文件. In [1]: # Import libraries import pandas as pd import ...
- 【Oracle】ORA-55610: Invalid DDL statement on history-tracked table
—删除表emp1时出现问题 SCOTT@GOOD> drop table emp1; drop table emp1 * ERROR at line 1: ORA-55610: Invalid ...
- sphinx with discuz
安装sphinx: sudo apt-get install sphinxsearch 配置: source discuz { type = mysql sql_host = xx.xx.xx.xx ...
- 三维重建:深度相机方案对比-KinectFusion的基本原理(尺度)
算法原理请参考此文: kinect fusion 3D重建基本算法 http://log.csdn.net/xiaohu50/article/details/51592503 三维重建为三维空间实 ...
- 三维重建:QT+OpenNI+Kinect图像校正
后记: 当时能不放弃这个方向是因为这里面涉及了一种很有效的三位场景存储方式,可能给出除图元建模之外的一种三维场景描述方式.这和Flash与位图的对比一样,基于图元的flash始终抵不过基于点描述的位图 ...
- table中的td内容过长显示为固定长度,多余部分用省略号代替
如何使td标签中过长的内容只显示为这个td的width的长度,之后的便以省略号代替. 给table中必须设置属性: table-layout: fixed; 然后给 td 设置: white-spac ...
- 操作ajax生成页面的一个问题
一般而言,js代码都放在页面的底部.在做项目的过程中,发现放在底部的代码没有执行,原来操作的是ajax生成的部分.这时候,页面加载js的顺序就要小心了.例子如下: <!doctype html& ...