


Ist Atomic Read-Modify-Write eine atomare oder trennbare Operation?
Atomare Read-Modify-Write-Operationen (RMW), wie z x.exchange() sind atomare Operationen, die einen Speicherort sowohl lesen als auch schreiben und sicherstellen, dass die Lese- und Schreibvorgänge der Reihe nach ausgeführt werden. Es ist jedoch nicht explizit definiert, ob diese Vorgänge als einzelne atomare Operation oder als Kombination aus Acquire Load und Release Store betrachtet werden.
Die Perspektive des Standards
Aus der Aus Sicht des C-Standards wird eine RMW-Operation als einzelne Operation betrachtet. Dies ist daran zu erkennen, dass es einen einzigen Namen (RMW) hat und im Standard als einzelne Operation bezeichnet wird. In [N4860](https://isocpp.org/files/papers/n4860.pdf) (Draft Working Paper std::memory_order) heißt es beispielsweise:
„Ein Lese-, Änderungs- und Schreibvorgang damit Bei der Speicherreihenfolge handelt es sich sowohl um eine Erfassungsoperation als auch um eine Freigabeoperation. Vorher oder nachher können keine Speicherlese- oder -schreibvorgänge im aktuellen Thread neu angeordnet werden speichern.“
Atomere vs. trennbare Operationen
Die Unterscheidung zwischen atomaren und trennbaren Operationen ist wichtig, da sie bestimmt, wie andere Operationen mit ihnen interagieren. Wenn eine RMW-Operation als atomar behandelt wird, bedeutet dies, dass sie im Hinblick auf andere Speicherzugriffe nicht neu angeordnet werden kann. Wenn es jedoch als trennbar behandelt wird, besteht die Möglichkeit einer Neuordnung zwischen den Lade- und Speicherkomponenten des Vorgangs.
Beispielcode
Betrachten Sie das folgende Codebeispiel , das x.exchange() und y.store() verwendet, um die Werte von zwei atomaren Variablen, x und, festzulegen y.
std::atomic<int> x, y; void thread_A() { x.exchange(1, std::memory_order_acq_rel); y.store(1, std::memory_order_relaxed); } void thread_B() { int yy = y.load(std::memory_order_acquire); int xx = x.load(std::memory_order_acquire); std::cout <p>Wenn x.exchange() als einzelne atomare Operation behandelt wird, bedeutet dies, dass die Lade- und Speicherkomponenten der Operation nicht neu angeordnet werden können. Daher wird Thread B immer beobachten, dass die Werte von x und y beide 1 oder beide 0 sind.</p> <p>Wenn x.exchange() jedoch als trennbar behandelt wird, bleibt die Möglichkeit offen, dass das Laden und Speichern erfolgt Bestandteile des Betriebs könnten neu angeordnet werden. In diesem Fall könnte Thread B möglicherweise die Werte von x und y als 0, 1 beobachten, da die Last von x vor dem Speichern nach y umgeordnet werden könnte.</p> <p><strong>Compiler-Implementierung und Standardinterpretation</strong></p> <p>Aus Sicht des Standards scheint es, dass Thread B 0, 1 nicht beachten sollte. Die ARM64-Implementierung des Codes legt dies jedoch nahe dass der RMW-Vorgang als trennbar behandelt wird, was die Möglichkeit einer Neuordnung zwischen den Lade- und Speicherkomponenten ermöglicht.</p> <p>Diese scheinbare Diskrepanz wirft die Frage auf, ob das cppreference-Zitat falsch ist oder ob es sich lediglich um ein Missverständnis des Standards handelt. Obwohl es möglich ist, dass das cppreference-Zitat nicht ganz korrekt ist, stimmt es mit der allgemeinen Behandlung von RMW-Operationen durch den Standard als einzelne atomare Operationen überein.</p> <p>Es ist wichtig zu beachten, dass der Standard das Verhalten von RMW-Operationen nicht explizit definiert alle Umstände. Insbesondere bietet es keine klare Anleitung dazu, wie Synchronisations-mit-Beziehungen auf RMW-Vorgänge angewendet werden. Daher kann Raum für unterschiedliche Interpretationen und Implementierungen von RMW-Operationen bestehen.</p></int>
Das obige ist der detaillierte Inhalt vonIst atomares Lesen, Ändern und Schreiben eine einzelne oder eine trennbare atomare Operation?. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

In diesem Artikel werden die C -Standard -Vorlagenbibliothek (STL) erläutert, die sich auf seine Kernkomponenten konzentriert: Container, Iteratoren, Algorithmen und Funktoren. Es wird beschrieben, wie diese interagieren, um die generische Programmierung, die Verbesserung der Codeeffizienz und die Lesbarkeit t zu ermöglichen

Dieser Artikel beschreibt die effiziente Verwendung von STL -Algorithmus in c. Es betont die Auswahl der Datenstruktur (Vektoren vs. Listen), Algorithmus -Komplexitätsanalyse (z. B. std :: sortieren vs. std :: partial_sort), Iteratoranwendungen und parallele Ausführung. Häufige Fallstricke wie

In diesem Artikel wird die effektive Ausnahmebehandlung in C, Covering Try, Catch und Wurp Mechanics, beschrieben. Es betont Best Practices wie Raii, die Vermeidung unnötiger Fangblöcke und die Protokollierung von Ausnahmen für robusten Code. Der Artikel befasst sich auch mit Perf

In dem Artikel wird die Verwendung von Move Semantics in C erörtert, um die Leistung zu verbessern, indem unnötiges Kopieren vermieden wird. Es umfasst die Implementierung von Bewegungskonstruktoren und Zuordnungsbetreibern unter Verwendung von STD :: MOVE

C 20 -Bereiche verbessern die Datenmanipulation mit Ausdruckskraft, Komposition und Effizienz. Sie vereinfachen komplexe Transformationen und integrieren sich in vorhandene Codebasen, um eine bessere Leistung und Wartbarkeit zu erhalten.

In dem Artikel wird der dynamische Versand in C, seine Leistungskosten und Optimierungsstrategien erörtert. Es unterstreicht Szenarien, in denen der dynamische Versand die Leistung beeinflusst, und vergleicht sie mit statischer Versand, wobei die Kompromisse zwischen Leistung und Betonung betont werden

Artikel erörtert den effektiven Einsatz von RValue -Referenzen in C für Bewegungssemantik, perfekte Weiterleitung und Ressourcenmanagement, wobei Best Practices und Leistungsverbesserungen hervorgehoben werden. (159 Charaktere)

C Speicherverwaltung verwendet neue, löschende und intelligente Zeiger. In dem Artikel werden manuelle und automatisierte Verwaltung erörtert und wie intelligente Zeiger Speicherlecks verhindern.


Heiße KI -Werkzeuge

Undresser.AI Undress
KI-gestützte App zum Erstellen realistischer Aktfotos

AI Clothes Remover
Online-KI-Tool zum Entfernen von Kleidung aus Fotos.

Undress AI Tool
Ausziehbilder kostenlos

Clothoff.io
KI-Kleiderentferner

AI Hentai Generator
Erstellen Sie kostenlos Ai Hentai.

Heißer Artikel

Heiße Werkzeuge

SublimeText3 Mac-Version
Codebearbeitungssoftware auf Gottesniveau (SublimeText3)

PHPStorm Mac-Version
Das neueste (2018.2.1) professionelle, integrierte PHP-Entwicklungstool

WebStorm-Mac-Version
Nützliche JavaScript-Entwicklungstools

ZendStudio 13.5.1 Mac
Leistungsstarke integrierte PHP-Entwicklungsumgebung

MinGW – Minimalistisches GNU für Windows
Dieses Projekt wird derzeit auf osdn.net/projects/mingw migriert. Sie können uns dort weiterhin folgen. MinGW: Eine native Windows-Portierung der GNU Compiler Collection (GCC), frei verteilbare Importbibliotheken und Header-Dateien zum Erstellen nativer Windows-Anwendungen, einschließlich Erweiterungen der MSVC-Laufzeit zur Unterstützung der C99-Funktionalität. Die gesamte MinGW-Software kann auf 64-Bit-Windows-Plattformen ausgeführt werden.