名稱空間
變體
操作

atomic_init

來自 cppreference.com
< c‎ | atomic
在標頭檔案 <stdatomic.h> 中定義
void atomic_init( volatile A* obj, C desired );
(C11 起)

使用值 desired 初始化預設構造的原子物件 obj。此函式不是原子操作:來自另一個執行緒的併發訪問,即使透過原子操作,也會導致資料競爭。

這是一個為所有 原子物件型別 A 定義的泛型函式。引數是指向 volatile 原子型別的指標,以接受非 volatile 和 volatile(例如記憶體對映 I/O)原子物件的地址,並且當對此 volatile 原子物件執行此操作時,volatile 語義得以保留。C 是對應於 A 的非原子型別。

未指定泛型函式的名稱是宏還是具有外部連結的識別符號。如果為了訪問實際函式而禁止宏定義(例如用括號括起來,如 (atomic_init)(...)),或者程式定義了一個與泛型函式名稱相同的外部識別符號,則行為未定義。

目錄

[編輯] 引數

obj - 指向要初始化的原子物件的指標
desired - 用於初始化原子物件的值

[編輯] 返回值

(無)

[編輯] 注意

atomic_init 是初始化動態分配的原子物件的唯一方法。例如

_Atomic int *p = malloc(sizeof(_Atomic int));
atomic_init(p, 42);

[編輯] 參考

  • C23 標準 (ISO/IEC 9899:2024)
  • 7.17.2.2 atomic_init 泛型函式 (p: 待定)
  • C17 標準 (ISO/IEC 9899:2018)
  • 7.17.2.2 atomic_init 泛型函式 (p: 201)
  • C11 標準 (ISO/IEC 9899:2011)
  • 7.17.2.2 atomic_init 泛型函式 (p: 274-275)

[編輯] 另請參閱

(C11)(C17 中已棄用)(C23 中已移除)
初始化新的原子物件
(函式宏) [編輯]
C++ 文件 for atomic_init