Namespaces
Variants

std:: atomic_flag_clear, std:: atomic_flag_clear_explicit

From cppreference.net
Concurrency support library
Threads
(C++11)
(C++20)
this_thread namespace
(C++11)
(C++11)
Cooperative cancellation
Mutual exclusion
Generic lock management
Condition variables
(C++11)
Semaphores
Latches and Barriers
(C++20)
(C++20)
Futures
(C++11)
(C++11)
(C++11)
Safe reclamation
Hazard pointers
Atomic types
(C++11)
(C++20)
Initialization of atomic types
(C++11) (deprecated in C++20)
(C++11) (deprecated in C++20)
Memory ordering
(C++11) (deprecated in C++26)
Free functions for atomic operations
Free functions for atomic flags
atomic_flag_clear atomic_flag_clear_explicit
(C++11) (C++11)
헤더 파일에 정의됨 <atomic>
void atomic_flag_clear ( volatile std:: atomic_flag * obj ) noexcept ;
(1) (C++11 이후)
void atomic_flag_clear ( std:: atomic_flag * obj ) noexcept ;
(2) (C++11 이후)
void atomic_flag_clear_explicit ( volatile std:: atomic_flag * obj,
std:: memory_order order ) noexcept ;
(3) (C++11 이후)
void atomic_flag_clear_explicit ( std:: atomic_flag * obj,
std:: memory_order order ) noexcept ;
(4) (C++11 이후)

std::atomic_flag 가 가리키는 obj 의 상태를 원자적으로 클리어 상태( false )로 변경합니다.

1,2) 메모리 동기화 순서는 std:: memory_order_seq_cst 입니다.
3,4) 메모리 동기화 순서는 order 입니다.
만약 order std:: memory_order_consume , std:: memory_order_acquire std:: memory_order_acq_rel 중 하나라면, 동작은 정의되지 않습니다.

목차

매개변수

obj - 접근할 std::atomic_flag 을 가리키는 포인터
order - 메모리 동기화 순서

참고 사항

std::atomic_flag_clear std::atomic_flag_clear_explicit 는 각각 obj - > clear ( ) obj - > clear ( order ) 로 구현될 수 있습니다.

결함 보고서

다음의 동작 변경 결함 보고서들은 이전에 발표된 C++ 표준에 소급 적용되었습니다.

DR 적용 대상 게시된 동작 올바른 동작
LWG 2138 C++11 order std:: memory_order_consume 일 수 있음 이 경우 동작은 정의되지 않음

참고 항목

락-프리 불리언 원자 타입
(클래스)
플래그를 원자적으로 true 로 설정하고 이전 값을 반환함
(함수)
주어진 원자 연산에 대한 메모리 순서 제약을 정의함
(열거형)
C 문서 for atomic_flag_clear , atomic_flag_clear_explicit