一个关于abs的小坑

版权声明:本文为博主原创文章,未经博主允许不得转载。 https://blog.csdn.net/jewelsu/article/details/88742408

上代码

    float b=1.0;
    float a=1.1;

if(abs(b-a)>0.0000000001)

{

  printf("true\n");

}

else

{

printf("false");

}

结果会是true还是false呢?设计意图肯定是要true的,在windows下用vs2010编译,出来结果也是对的。但是在linux下结果却是false,(编译器为g++ (GCC) 4.4.7 20120313 (Red Hat 4.4.7-3))。

原因在abs这个函数上,可能gcc上这个函数只能处理int型,所以先将b-a转成int型,就成了0。而vs2010的编译器处理了这种情况。

解决方案是使用fabs这函数就行了。

猜你喜欢

转载自blog.csdn.net/jewelsu/article/details/88742408