C++编程可能会忽视的一个“小问题”

来源:互联网 发布:win10最好用优化软件 编辑:程序博客网 时间:2024/05/16 11:41

又好久没写blog了,最近一直忙工作的事情,倒不是说没时间,而是没什么心思整理思路,这篇文章也不是什么大不了的文章,但确实是我最近遇到的一个问题,我在调试一个程序的时候时不时出现一些莫名其妙的问题,这些问题也就是那种无规律重现的非常棘手的bug,相信做过开发的人都深有体会。

当然我最后是fix了这些bug,对我这种高手而言,没什么修不了的错误,(哈哈)要的只是时间而已,但从中发现了一个C++编程的小问题,哦,顺便提一下,其实到最后对你造成困扰的都是小问题。言归正传,看代码:

  1. int main(int argc, char* argv[])
  2. {
  3.     double d1=0.1;
  4.     double d2=0.1f;
  5.     printf("[%.12f] [%.12f]/n", d1, d2);
  6.     if (d1<d2 || d2<d1)
  7.         printf("d1, d2 Not equal!!/n");
  8.     
  9.     double d3=0.1;
  10.     printf("[%.12f] [%.12f]/n", d1, d3);
  11.     if (d1<d3 || d3<d1)
  12.         printf("d1, d3 Not equal!!/n");
  13.     
  14.     return 0;
  15. }

程序实在简单得没法再简单,我就不多说了,大家估计下结果,然后用自己的编译器验证一下,本人用的是VC++ 6.0,这是本人的运行结果:

[0.100000000000] [0.100000001490]
d1, d2 Not equal!!
[0.100000000000] [0.100000000000]
Press any key to continue

所以0.1和0.1f是不相同的,0.1f是float型,而0.1是double型,将0.1f赋值给double型的d2,就要发生类型转换,运气好的时候当然是没问题,但我的运气通常不会太好,也许你的编译器不会出现问题,或者不是每次都出问题,我就不一一验证了。

结论:所以给double赋值的时候直接写我们常规的小数即可,不要画蛇添足地加上“f”后缀,没准哪天出问题了急得你焦头烂额。

下次……下次……一定写点好文章……