std::atomic_ref<T>::fetch_xor
Von cppreference.com
< cpp | atomic | atomic ref
| Nur bereitgestellt, wenn T ein ganzzahliger Typ außer cv bool ist |
||
| value_type fetch_xor( value_type arg, std::memory_order order = |
(seit C++20) | |
Atomar ersetzt den aktuellen Wert des referenzierten Objekts durch das Ergebnis der bitweisen XOR-Operation des Wertes und arg. Diese Operation ist eine Lese-Modifizierungs-Schreib-Operation. Der Speicher wird gemäß dem Wert von order beeinflusst.
Diese Überladung nimmt nur an der Überladungsauflösung teil, wenn std::is_const_v<T> false ist.
[bearbeiten] Parameter
| arg | - | das andere Argument der bitweisen XOR-Operation |
| Reihenfolge | - | Speicherreihenfolgebeschränkungen, die durchgesetzt werden sollen |
[bearbeiten] Rückgabewert
Der Wert des referenzierten Objekts, unmittelbar vor den Auswirkungen dieser Funktion.
[bearbeiten] 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 |
constrained to accept only non-const T |