首頁 後端開發 C++ 為什麼浮點運算在 x86 和 x64 架構之間會產生不同的結果?

為什麼浮點運算在 x86 和 x64 架構之間會產生不同的結果?

Nov 03, 2024 am 03:12 AM

Why does floating-point arithmetic produce different results between x86 and x64 architectures?

浮點運算的差異:x86 與x64

在涉及浮點運算的程式碼片段中,MS VS 之間出現不一致2010年建構了針對x86 和x64 架構的版本。程式碼如下:

float a = 50.0f;
float b = 65.0f;
float c =  1.3f;
float d = a*c;
bool bLarger1 = d < b;
bool bLarger2 = (a*c) < b;
登入後複製

差異:

  • x86 建構: 變數bLarger1 為false(d 和bse)都為false設定為65.0),而bLarger2 為true。
  • x64 版本: bLarger1 和 bLarger2 皆為 false。

潛在問題:

差異源自於表達式 bool bLarger2 = (a*c)

浮點單位的差異:

主要差異在於兩者使用的浮點單位架構。 x86架構使用x87浮點單元,它以比單精度(通常是雙精度)更高的精度執行計算。相較之下,x64 架構使用 SSE 浮點單元,執行純單精度運算。

對乘法的影響:

在 bLarger1 表達式中, a 和 c 的乘法由硬體乘法指令執行。此指令使用雙精度精度,導致 d 設定為 65.0。

但是,在 bLarger2 表達式中,由於型別轉換(a*c),乘法明確以單精確度執行。這會導致 (a*c) 設定為 64.999992。

x87 精度控制:

預設情況下,x87 單元以雙精度運作。但是,可以使用 _controlfp 函數說服單元執行單精度計算。

_controlfp(_PC_24, _MCW_PC);
登入後複製

將此行新增至 32 位元程式碼,bLarger1 和 bLarger2 都會設定為 false。

編譯器選項:

在較新版本的 Visual Studio 中,即使對於 32 位元目標,編譯器也可能會發出 SSE 指令。這確保了不同架構之間浮點運算的一致性。

以上是為什麼浮點運算在 x86 和 x64 架構之間會產生不同的結果?的詳細內容。更多資訊請關注PHP中文網其他相關文章!

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

熱門文章

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

熱門文章

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

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

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

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

Gulc:從頭開始建造的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