std::atomic_ref<T>:: fetch_xor
|
|
|||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
|
Nur bereitgestellt, wenn
T
ein integraler Typ außer
cv
bool
ist
|
||
|
value_type fetch_xor
(
value_type arg,
std::
memory_order
order
=
|
(seit C++20) | |
Ersetzt atomar den aktuellen Wert des referenzierten Objekts mit dem Ergebnis der bitweisen XOR-Operation des Werts und arg . Dieser Vorgang ist eine Read-Modify-Write-Operation. Der Speicher wird gemäß dem Wert von order beeinflusst.
Diese Überladung nimmt nur dann an der Überladungsauflösung teil, wenn std:: is_const_v < T > false ist.
Parameter
| arg | - | das andere Argument der bitweisen XOR-Operation |
| order | - | Speicherreihenfolge-Beschränkungen zur Durchsetzung |
Rückgabewert
Der Wert des referenzierten Objekts unmittelbar vor den Auswirkungen dieser Funktion.
Fehlerberichte
Die folgenden verhaltensändernden Fehlerberichte wurden rückwirkend auf zuvor veröffentlichte C++-Standards angewendet.
| DR | Angewendet auf | Verhalten wie veröffentlicht | Korrigiertes Verhalten |
|---|---|---|---|
|
LWG 3508
( P3323R1 ) |
C++20 |
fetch_xor
war bedeutungslos für
const
T
|
eingeschränkt um nur non-const
T
zu akzeptieren
|