Namespaces
Variants

atomic_exchange, atomic_exchange_explicit

From cppreference.net
헤더 파일에 정의됨 <stdatomic.h>
C atomic_exchange ( volatile A * obj, C desired ) ;
(1) (C11 이후)
C atomic_exchange_explicit ( volatile A * obj, C desired, memory_order order ) ;
(2) (C11 이후)

obj 가 가리키는 값을 원자적으로 desired 로 교체하고, 이전에 obj 가 보유하던 값을 반환합니다. 이 연산은 읽기-수정-쓰기 연산입니다. 첫 번째 버전은 메모리 접근을 memory_order_seq_cst 에 따라 정렬하며, 두 번째 버전은 메모리 접근을 order 에 따라 정렬합니다.

이것은 모든 generic function 에 대해 정의된 atomic object types A 입니다. 인자는 volatile 및 비-volatile 원자 객체의 주소를 모두 수용하기 위해 volatile 원자 타입에 대한 포인터이며, volatile 원자 객체에 이 연산을 적용할 때 volatile 의미론이 유지됩니다. C A 에 해당하는 비-원자 타입입니다.

제네릭 함수의 이름이 매크로인지 외부 링크를 가진 식별자인지는 명시되지 않습니다. 실제 함수에 접근하기 위해 매크로 정의를 억제하는 경우(예: ( atomic_exchange ) ( ... ) 와 같이 괄호로 묶은 경우), 또는 프로그램이 제네릭 함수 이름으로 외부 식별자를 정의하는 경우, 그 동작은 정의되지 않습니다.

목차

매개변수

obj - 수정할 원자적 객체에 대한 포인터
desired - 원자적 객체를 대체할 값
order - 이 연산에 대한 메모리 동기화 순서: 모든 값이 허용됨

반환값

원자 객체 obj 가 이전에 보유하고 있던 값.

참고문헌

  • C17 표준 (ISO/IEC 9899:2018):
  • 7.17.7.3 atomic_exchange 제네릭 함수 (p: 207)
  • C11 표준 (ISO/IEC 9899:2011):
  • 7.17.7.3 atomic_exchange 제네릭 함수 (p: 283)

참고 항목

예상한 값과 동일한 경우 원자적 객체와 값을 교환하고, 그렇지 않으면 이전 값을 읽습니다
(함수)
C++ documentation for atomic_exchange , atomic_exchange_explicit