首頁 後端開發 C++ 為什麼在 C 中比較浮點數和雙精確度文字會產生意外的結果?

為什麼在 C 中比較浮點數和雙精確度文字會產生意外的結果?

Dec 15, 2024 pm 06:48 PM

Why does comparing floats to double literals in C produce unexpected results?

浮點比較難題

考慮以下C 碼:

int main()
{
    float a = 0.7;
    float b = 0.5;
    if (a < 0.7)
    {
        if (b < 0.5) printf("2 are right");
        else         printf("1 is right");
    }
    else printf("0 are right");
}
登入後複製

您直觀地期望輸出為是「 0是對的」。然而,令人驚訝的結果是“1是正確的”。為什麼會出現這種情況?

浮點比較的陷阱

關鍵在於C中浮點數和雙精確度數的差異。程式碼中,變數a和b被宣告為float,即32位元浮點數。然而,這兩個比較(a

在比較期間,浮點變數被提升為雙精度數,從而允許更高的範圍和精度。然而,由於浮點數的精度有限,這種轉換可能會引入微妙的偽影。在這種情況下,浮點數 0.7 並不完全等於雙精確度數 0.7。

具體來說,浮點數 0.7 在 IEEE 754 標準中表示為 0x3f000000。當提升為雙精度時,該值並不是 0.7 的精確表示。相反,它會變得稍大一些,大約為 0x3f00000000000000(大約 0.7000000000000001)。

意外結果的原因

由於此促銷,條件 a

0.7 變為 true,因為 a 的雙重表示略小於 0.7。隨後,第二次比較b<0。 0.5 的計算結果為 false,因為 b(精確表示為雙精度型)等於 0.5。因此,程式碼列印「1 是正確的。」

解決方案

要解決此問題,您可以:
  • 更改變數a 和b 宣告為雙精確度數,或
  • 更改文字0.7 和0.5指定為float

以上是為什麼在 C 中比較浮點數和雙精確度文字會產生意外的結果?的詳細內容。更多資訊請關注PHP中文網其他相關文章!

本網站聲明
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn

熱門文章

倉庫:如何復興隊友
3 週前 By 尊渡假赌尊渡假赌尊渡假赌
Hello Kitty Island冒險:如何獲得巨型種子
3 週前 By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O.能量晶體解釋及其做什麼(黃色晶體)
1 週前 By 尊渡假赌尊渡假赌尊渡假赌

熱門文章

倉庫:如何復興隊友
3 週前 By 尊渡假赌尊渡假赌尊渡假赌
Hello Kitty Island冒險:如何獲得巨型種子
3 週前 By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O.能量晶體解釋及其做什麼(黃色晶體)
1 週前 By 尊渡假赌尊渡假赌尊渡假赌

熱門文章標籤

記事本++7.3.1

記事本++7.3.1

好用且免費的程式碼編輯器

SublimeText3漢化版

SublimeText3漢化版

中文版,非常好用

禪工作室 13.0.1

禪工作室 13.0.1

強大的PHP整合開發環境

Dreamweaver CS6

Dreamweaver CS6

視覺化網頁開發工具

SublimeText3 Mac版

SublimeText3 Mac版

神級程式碼編輯軟體(SublimeText3)

Gulc:從頭開始建造的C庫 Gulc:從頭開始建造的C庫 Mar 03, 2025 pm 05:46 PM

Gulc:從頭開始建造的C庫

c語言函數返回值的類型有哪些?返回值是由什麼決定的? c語言函數返回值的類型有哪些?返回值是由什麼決定的? Mar 03, 2025 pm 05:52 PM

c語言函數返回值的類型有哪些?返回值是由什麼決定的?

c語言函數格式字母大小寫轉換步驟 c語言函數格式字母大小寫轉換步驟 Mar 03, 2025 pm 05:53 PM

c語言函數格式字母大小寫轉換步驟

c語言函數的定義和調用規則是什麼 c語言函數的定義和調用規則是什麼 Mar 03, 2025 pm 05:53 PM

c語言函數的定義和調用規則是什麼

distinct用法和短語分享 distinct用法和短語分享 Mar 03, 2025 pm 05:51 PM

distinct用法和短語分享

c語言函數返回值在內存保存在哪裡? c語言函數返回值在內存保存在哪裡? Mar 03, 2025 pm 05:51 PM

c語言函數返回值在內存保存在哪裡?

C標準模板庫(STL)如何工作? C標準模板庫(STL)如何工作? Mar 12, 2025 pm 04:50 PM

C標準模板庫(STL)如何工作?

如何有效地使用STL(排序,查找,轉換等)的算法? 如何有效地使用STL(排序,查找,轉換等)的算法? Mar 12, 2025 pm 04:52 PM

如何有效地使用STL(排序,查找,轉換等)的算法?

See all articles