题目1:int bool float与0的比较。其值为x

时间:2021-05-13 02:55:04

1.bool与0的比较。

bool规定为ture和false,但是关于ture值的定义在不同的环境和系统中,定义可能不同,C++中规定ture为1,但是VB中规定ture为-1,所以不要把bool类型的变量与ture、1、-1、0直接进行比较,这很有可能会造成程序错误。正规的写法为:

if(flag)

或者if(!flag),其中flag为bool类型。

2、整型变量和0值的比较

if(value==0)

if(value!=0),其中value为整型变量

3、浮点(float和double)变量和0值的比较

浮点变量在计算机中表示时有一定的精度和范围,如果超出精度限制,则计算机会进行截断处理,所以在计算机中不能直接用==和!=来直接对两个浮点数进行比较(注意:这里所谓的不能并不是说不可以这样写,实际上如果这样写编译器是不会报错的,但是很可能会导致程序不按我们预期的结果执行,所以为了避免错误的发生,还是不要这样写的好

两个浮点数正确的比较方法为:

if(abs(a-b)<=EPSILON),

if(abs(a-b)>EPSILON),其中EPSILON为精度

同理浮点数与0值比较的正确方法为

if(abs(x)<=EPSILON),

if(abs(x)>EPSILON)

或者,如果不知道精度的情况下,可以这样写: if((a>=-0.0001)&&a<=0.00001)) ,如果这个if的条件为真,就代表a是等于0的。(因为float型是保证5位小数有效的,double是保证13位小数有效的。)

4、指针变量和0值的比较

if(p==NULL)

if(p!=NULL)