首頁 >後端開發 >C++ >x86 加載和儲存的原子性如何?

x86 加載和儲存的原子性如何?

Patricia Arquette
Patricia Arquette原創
2024-12-03 03:21:10291瀏覽

How Atomic Are x86 Loads and Stores, and What Factors Affect Atomicity?

x86 上載入和儲存的原子性

x86 架構保證對齊載入和儲存的原子性,最多可達資料路徑的大小核心、記憶體和I/O 匯流排之間。這意味著單一操作將不可分割地發生,任何其他觀察到它的操作都會將其視為已完全發生或根本沒有發生。

在內部,CPU 可以「免費」為對齊操作實現原子性,因為資料傳輸透過足夠寬的資料匯流排或透過單一訊息進行。對於更廣泛的存取或未對齊的操作,可能需要將操作拆分為更小的區塊並執行更複雜的操作。

原子操作與快取

原子操作可以完全發生在快取中,只要操作不跨越快取行邊界。這意味著對快取的修改足以保證原子性。

原子讀-修改-寫

原子讀-修改-寫(RMW)操作更困難來實作。 CPU 可以將快取行保持在已修改狀態,並在操作進行時忽略快取一致性訊息,使其對其他核心而言顯得原子。

未對齊鎖定操作

未對齊的鎖定操作可能需要更複雜的硬體幹預,例如在操作期間採取總線鎖定以防止其他訪問。

以上是x86 加載和儲存的原子性如何?的詳細內容。更多資訊請關注PHP中文網其他相關文章!

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