怎么樣判斷兩個浮點數精確相等?一般來說是兩個數差的絕對值和一個極小值比較,如果小于這個極小就,就認為是相等。
前兩天在LinuxSir上看到一個貼子,討論這個問題,發現可以精確比較相等。
代碼如下:























發現用這種方法在Ubuntu8.04,GCC4.24的情況下通過。不過這種方法個人感覺只能用來比較一個程序內部生成的浮點數的運算。
如果兩個浮點數是由兩臺不同平臺的機器運行的程序生成,或者不同編譯器生成的程序運行產生,則可能根據無法得到相等的結果。
因現在只有x86的機器,誰手上有ARM平臺之類的,請幫忙測試一下。謝謝
當直接用==比較兩個浮點數時,隨著整數部分增加,精度急劇下降
當比較0.000...001和0.000.。0011時,到65個零都沒有問題,能得到正確結果
當比較1.000..001和0.000.00011時,小數點后14個零時,就不能得到正確結果。