C++編程可能會忽視的一個“小問題”

來源:互聯網
上載者:User

又好久沒寫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”尾碼,沒準哪天出問題了急得你焦頭爛額。

下次……下次……一定寫點好文章……

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.