atomic_exchange, atomic_exchange_explicit
|
헤더 파일에 정의됨
<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
|
|