close
Пространства имён
Варианты
Действия

std::atomic_fetch_xor, std::atomic_fetch_xor_explicit

Материал из cppreference.com

<metanoindex/>

 
 
Библиотека атомарных операций
 
<tbody> </tbody>
Определено в заголовочном файле <atomic>
template< class Integral > Integral atomic_fetch_xor( std::atomic<Integral>* obj, Integral arg );
(1) (начиная с C++11)
template< class Integral > Integral atomic_fetch_xor( volatile std::atomic<Integral>* obj, Integral arg );
(2) (начиная с C++11)
template< class Integral > Integral atomic_fetch_xor_explicit( std::atomic<Integral>* obj, Integral arg, std::memory_order order );
(3) (начиная с C++11)
template< class Integral > Integral atomic_fetch_xor_explicit( volatile std::atomic<Integral>* obj, Integral arg, std::memory_order order );
(4) (начиная с C++11)

1-2)

Атомарно заменяет значение указано на arg с результатом побитового XOR между старым значением obj и arg, и возвращает значение obj состоялась ранее, как по obj->fetch_and(arg)
Оригинал:
Atomically replaces the value pointed by arg with the result of bitwise XOR between the old value of obj and arg, and returns the value obj held previously, as if by obj->fetch_and(arg)
Текст был переведён автоматически используя Переводчик Google.
Вы можете проверить и исправить перевод. Для инструкций щёлкните сюда.

3-4)

Атомарно заменяет значение указано на arg с результатом побитового XOR между старым значением obj и arg, и возвращает значение obj состоялась ранее, как по obj->fetch_and(arg, order)
Оригинал:
Atomically replaces the value pointed by arg with the result of bitwise XOR between the old value of obj and arg, and returns the value obj held previously, as if by obj->fetch_and(arg, order)
Текст был переведён автоматически используя Переводчик Google.
Вы можете проверить и исправить перевод. Для инструкций щёлкните сюда.

Параметры

obj
Указатель на атомном объекте изменить
Оригинал:
pointer to the atomic object to modify
Текст был переведён автоматически используя Переводчик Google.
Вы можете проверить и исправить перевод. Для инструкций щёлкните сюда.
arg
значение побитовое XOR со значением, хранящимся в атомном объекте
Оригинал:
the value to bitwise XOR to the value stored in the atomic object
Текст был переведён автоматически используя Переводчик Google.
Вы можете проверить и исправить перевод. Для инструкций щёлкните сюда.
order
памяти sycnhronization заказа для этой операции: все допустимые значения .
Оригинал:
the memory sycnhronization ordering for this operation: all values are permitted.
Текст был переведён автоматически используя Переводчик Google.
Вы можете проверить и исправить перевод. Для инструкций щёлкните сюда.

Возвращаемое значение

Значение состоялась ранее атомный объект, на который указывает obj
Оригинал:
The value held previously by the atomic object pointed to by obj
Текст был переведён автоматически используя Переводчик Google.
Вы можете проверить и исправить перевод. Для инструкций щёлкните сюда.

Исключения

спецификация noexcept:  
noexcept
  

Возможная реализация

template< class T >
typename std::enable_if<std::is_integral<T>::value && !std::is_same<T, bool>::value, T>::type
atomic_fetch_xor( std::atomic<T>* obj, T arg );
{
    return obj->fetch_xor(arg);
}

Пример

См. также

атомарно выполняет побитовое исключающее ИЛИ между аргументом и значением атомарного объекта и получает значение, сохранённое ранее
(public функция-элемент std::atomic) [править]
заменяет атомарный объект результатом поразрядного ИЛИ с неатомарным аргументом и получает предыдущее атомарное значение
(шаблон функции) [править]
заменяет атомарный объект результатом поразрядного И с неатомарным аргументом и получает предыдущее атомарное значение
(шаблон функции) [править]
Документация C по atomic_fetch_xor, atomic_fetch_xor_explicit