分享
 
 
 

C++数据类型的属性与限制

王朝c/c++·作者佚名  2008-06-01
窄屏简体版  字體: |||超大  

在C++中,每一种内置的数据类型都拥有不同的属性,其中包含的信息对设计程序来说是非常重要的,下面来看一下,<limits>库是怎样有助于访问这些信息的。

C++中约有10种截然不同的整数类型及超过3种的浮点类型,而每种数据类型都有不同的数值属性,如数值范围、能表示的最大位数、或各自的精度等等,这些属性对金融、科学、图形、数字信号处理等程序来说是极其重要的。本文讨论使用<limits>库,怎样在程序中获得这些基本数据类型的数值属性。

"一个double类型中能存储多少位?","signed long能表示的最大正数是多少?"假如这些问题的答案对你的程序很重要,那么你怎样以一种方便、且系统的方法来得到答案呢?答案就是:使用标准<limits>库。

浮点的乐章

C++中浮点数据类型精度是有限的,某些与硬件有关的特性导致了浮点数据类型的截断与取整。现在,你就明白为什么2.0/3.0的结果大概是0.66666666666666663了吧,"数字噪音"通常是大多数bug的源头,请看如下例子:

double d1=2., d2=3.;

d1/=d2; // 2/3

if (d1*10==(20./d2)) //条件本应该是"真"的,但,哎!

{

//永远不可能执行到的代码

do_equal();

}

花括号中的代码行永远也不可能执行,因为在 == 两边的表达式结果会有稍微的差别,d1*10的结果是6.6666666666666661,而20./d2的结果是6.6666666666666670,正是这种浮点算法的截断与近似值导致了此差异的发生。在此,可使用定标整数,但有时这并不是一个妥善的解决办法,试想有一张计算复数公式的电子表格--它必须使用浮点类型,在这种情况下,小正数(epsilon)常量这个问题就来了,小正数通常为可用给定数据类型的大于1的最小值与1之差来表示。举例来说,double类型的小正数为:

#include <iostream>

#include <limits>

using namespace std;

cout << numeric_limits<double>::epsilon( ) << endl; //输出:2.22045e-016

为减少if语句中数字噪音带来的影响,可用一个检查两值粗略相等的表达式来代替 == 操作符。如:

if ( ((d1*10)-(20.0/d2)) <= numeric_limits<double>::epsilon())

{

do_equal();

}

假如double类型的(d1*10)-(20.0/d2)结果不大于小正数,那么它几乎为零,因此,两个子表达式结果相等,应用此技巧可有效降低错误的阀值。例如,假如十亿分之一或者更小的数值,对你的程序来说无关紧要,那么可试下以下的技巧:

const double BILLIONTH=1./1000000000;

if ( ((d1*10)-(20.0/d2)) <= BILLIONTH)

此处请记住,小正数是最小的偏差极限。

比double更好

选择一种浮点数据类型的标准,是它可以在精度无损的情况下最大存储的十进制位数。例如,假设你的程序必须支持到16位的十进制数,那么应该使用double、long double还是用户自定义类型呢?要解答此问题,可使用numeric_limits::digits10常量,它会告诉你在精度无损情况下某种类型可表示的最大十进制位数:

cout<<numeric_limits<double>::digits10<<endl;//输出:15

看起来double并不支持这种精度,那么long double呢?

cout<<numeric_limits<long double>::digits10<<endl; //输出:18

对了,它就可以。请注重,digits10对整型数也同样适用:

cout<<numeric_limits<long>::digits10<<endl; //输出:9

最大值与最小值

最大值与最小值即是对相应类型调用numeric_limits::max()和numeric_limits:min()所得到的值:

cout<<numeric_limits<int>::max()<<endl;// 2147483647

无限的<limits>

在IEC 559规范实现中,浮点数据类型可表示为"不是一个数字"或NaN。NaN是一种非凡的编码,其代表某种非法数字,可由非法指令产生,或意为指示一个不应被忽略的数值。假如出现在表达式中的NaN没有发出一个"信号",则其为"安静"状态;否则,其为一个发"信号"的NaN。下面的例子检查在目标平台上支持哪种NaN类型,并把NaN的值赋给一个变量:

double d=0;

if(numeric_limits<double>::has_quiet_NaN)

d=numeric_limits<double>::quiet_NaN();

else if (numeric_limits<double>::has_signaling_NaN)

d=numeric_limits<double>::signaling_NaN();

else cerr<<"NaN for double isn't supported";

无限在此是一种非凡的情况,其通常由被零除或其他操作产生。下例代码检查目标平台上是否定义了一种非凡的无限码,并把此值赋给一个变量:

float f=0;

if(numeric_limits<float>::has_infinity)

f=numeric_limits<float>::infinity();

else cerr<<"infinity for float isn't supported";

 
 
 
免责声明:本文为网络用户发布,其观点仅代表作者个人观点,与本站无关,本站仅提供信息存储服务。文中陈述内容未经本站证实,其真实性、完整性、及时性本站不作任何保证或承诺,请读者仅作参考,并请自行核实相关内容。
2023年上半年GDP全球前十五强
 百态   2023-10-24
美众议院议长启动对拜登的弹劾调查
 百态   2023-09-13
上海、济南、武汉等多地出现不明坠落物
 探索   2023-09-06
印度或要将国名改为“巴拉特”
 百态   2023-09-06
男子为女友送行,买票不登机被捕
 百态   2023-08-20
手机地震预警功能怎么开?
 干货   2023-08-06
女子4年卖2套房花700多万做美容:不但没变美脸,面部还出现变形
 百态   2023-08-04
住户一楼被水淹 还冲来8头猪
 百态   2023-07-31
女子体内爬出大量瓜子状活虫
 百态   2023-07-25
地球连续35年收到神秘规律性信号,网友:不要回答!
 探索   2023-07-21
全球镓价格本周大涨27%
 探索   2023-07-09
钱都流向了那些不缺钱的人,苦都留给了能吃苦的人
 探索   2023-07-02
倩女手游刀客魅者强控制(强混乱强眩晕强睡眠)和对应控制抗性的关系
 百态   2020-08-20
美国5月9日最新疫情:美国确诊人数突破131万
 百态   2020-05-09
荷兰政府宣布将集体辞职
 干货   2020-04-30
倩女幽魂手游师徒任务情义春秋猜成语答案逍遥观:鹏程万里
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案神机营:射石饮羽
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案昆仑山:拔刀相助
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案天工阁:鬼斧神工
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案丝路古道:单枪匹马
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案镇郊荒野:与虎谋皮
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案镇郊荒野:李代桃僵
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案镇郊荒野:指鹿为马
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案金陵:小鸟依人
 干货   2019-11-12
倩女幽魂手游师徒任务情义春秋猜成语答案金陵:千金买邻
 干货   2019-11-12
 
推荐阅读
 
 
 
>>返回首頁<<
 
靜靜地坐在廢墟上,四周的荒凉一望無際,忽然覺得,淒涼也很美
© 2005- 王朝網路 版權所有