Standard library header <stdatomic.h> (C11)
From cppreference.net
Этот заголовок предоставляет атомарные операции , в частности, он является частью библиотеки поддержки многопоточности .
Содержание |
Атомарные операции
Операции над атомарными типами |
|
|
указывает, что данный атомарный тип является безблокировочным
(макроконстанта) |
|
|
(C11)
|
указывает, является ли атомарный объект свободным от блокировок
(функция) |
|
сохраняет значение в атомарном объекте
(функция) |
|
|
считывает значение из атомарного объекта
(функция) |
|
|
обменивает значение со значением атомарного объекта
(функция) |
|
|
заменяет значение атомарного объекта, если старое значение соответствует ожидаемому, в противном случае считывает старое значение
(функция) |
|
|
атомное сложение
(функция) |
|
|
атомарное вычитание
(функция) |
|
|
атомное побитовое ИЛИ
(функция) |
|
|
атомическое побитовое исключающее ИЛИ
(функция) |
|
|
атомное побитовое И
(функция) |
|
Тип флага и операции |
|
|
(C11)
|
безблокируемый атомарный булевый флаг
(struct) |
|
устанавливает atomic_flag в true и возвращает предыдущее значение
(функция) |
|
|
устанавливает atomic_flag в false
(функция) |
|
Инициализация |
|
|
(C11)
|
инициализирует существующий атомарный объект
(функция) |
|
(C11)
(deprecated in C17)
(removed in C23)
|
инициализирует новый атомарный объект
(макрос функции) |
|
(C11)
|
инициализирует новый
atomic_flag
(макроконстанта) |
Порядок синхронизации памяти |
|
|
(C11)
|
определяет ограничения упорядочения памяти
(enum) |
|
(C11)
|
разрывает цепочку зависимостей для
memory_order_consume
(функциональный макрос) |
|
(C11)
|
универсальная примитивная синхронизация барьера, зависящая от порядка памяти
(функция) |
|
(C11)
|
барьер между потоком и обработчиком сигнала, выполняемым в том же потоке
(функция) |
Удобные псевдонимы типов |
|
| Имя типа-псевдонима | Полное имя типа |
atomic_bool
(C11)
|
_Atomic _Bool |
atomic_char
(C11)
|
_Atomic char |
atomic_schar
(C11)
|
_Atomic signed char |
atomic_schar
(C11)
|
_Atomic signed char |
atomic_uchar
(C11)
|
_Atomic unsigned char |
atomic_short
(C11)
|
_Atomic short |
atomic_ushort
(C11)
|
_Atomic unsigned short |
atomic_int
(C11)
|
_Atomic int |
atomic_uint
(C11)
|
_Atomic unsigned int |
atomic_uint
(C11)
|
_Atomic unsigned int |
atomic_long
(C11)
|
_Atomic long |
atomic_ulong
(C11)
|
_Atomic unsigned long |
atomic_llong
(C11)
|
_Atomic long long |
atomic_ullong
(C11)
|
_Atomic unsigned long long |
atomic_char8_t
(C23)
|
_Atomic char8_t |
atomic_char16_t
(C11)
|
_Atomic char16_t |
atomic_char32_t
(C11)
|
_Atomic char32_t |
atomic_wchar_t
(C11)
|
_Atomic wchar_t |
atomic_int_least8_t
(C11)
|
_Atomic int_least8_t |
atomic_uint_least8_t
(C11)
|
_Atomic uint_least8_t |
atomic_int_least16_t
(C11)
|
_Atomic int_least16_t |
atomic_uint_least16_t
(C11)
|
_Atomic uint_least16_t |
atomic_int_least32_t
(C11)
|
_Atomic int_least32_t |
atomic_uint_least32_t
(C11)
|
_Atomic uint_least32_t |
atomic_int_least64_t
(C11)
|
_Atomic int_least64_t |
atomic_uint_least64_t
(C11)
|
_Atomic uint_least64_t |
atomic_int_fast8_t
(C11)
|
_Atomic int_fast8_t |
atomic_uint_fast8_t
(C11)
|
_Atomic uint_fast8_t |
atomic_int_fast16_t
(C11)
|
_Atomic int_fast16_t |
atomic_uint_fast16_t
(C11)
|
_Atomic uint_fast16_t |
atomic_int_fast32_t
(C11)
|
_Atomic int_fast32_t |
atomic_uint_fast32_t
(C11)
|
_Atomic uint_fast32_t |
atomic_int_fast64_t
(C11)
|
_Atomic int_fast64_t |
atomic_uint_fast64_t
(C11)
|
_Atomic uint_fast64_t |
atomic_intptr_t
(C11)
|
_Atomic intptr_t |
atomic_uintptr_t
(C11)
|
_Atomic uintptr_t |
atomic_size_t
(C11)
|
_Atomic size_t |
atomic_ptrdiff_t
(C11)
|
_Atomic ptrdiff_t |
atomic_intmax_t
(C11)
|
_Atomic intmax_t |
atomic_intmax_t
(C11)
|
_Atomic intmax_t |
atomic_uintmax_t
(C11)
|
_Atomic uintmax_t |
atomic_uintmax_t
(C11)
|
_Atomic uintmax_t |
Синопсис
|
Этот раздел не завершён
Причина: добавить больше из 7.17 Atomics <stdatomic.h> и B.16 Atomics <stdatomic.h> |
#define __STDC_VERSION_STDATOMIC_H__ 202311L void atomic_init(volatile A* obj, /*C*/ value); /*type*/ kill_dependency(/*type*/ y); void atomic_thread_fence(memory_order order); void atomic_signal_fence(memory_order order); bool atomic_is_lock_free(const volatile A* obj); void atomic_store(volatile A* object, /*C*/ desired); void atomic_store_explicit(volatile A* object, /*C*/ desired, memory_order order); /*C*/ atomic_load(const volatile A* object); /*C*/ atomic_load_explicit(const volatile A* object, memory_order order); /*C*/ atomic_exchange(volatile A* object, /*C*/ desired); /*C*/ atomic_exchange_explicit(volatile A* object, /*C*/ desired, memory_order order); bool atomic_compare_exchange_strong(volatile A* object, /*C*/* expected, /*C*/ desired); bool atomic_compare_exchange_strong_explicit(volatile A* object, /*C*/* expected, /*C*/ desired, memory_order success, memory_order failure); bool atomic_compare_exchange_weak(volatile A* object, /*C*/* expected, /*C*/ desired); bool atomic_compare_exchange_weak_explicit(volatile A* object, /*C*/* expected, /*C*/ desired, memory_order success, memory_order failure); /*C*/ /*atomic_fetch_key*/(volatile A* object, M operand); /*C*/ /*atomic_fetch_key_explicit*/(volatile A* object, M operand, memory_order order); bool atomic_flag_test_and_set(volatile atomic_flag* object); bool atomic_flag_test_and_set_explicit(volatile atomic_flag* object, memory_order order); void atomic_flag_clear(volatile atomic_flag* object); void atomic_flag_clear_explicit(volatile atomic_flag* object, memory_order order);
`, `
` и атрибуты сохранены в оригинальном виде.