函数

GLibatomic_pointer_and

自:2.30

声明 [src]

guintptr
g_atomic_pointer_and (
  void* atomic,
  gsize val
)

说明 [src]

atomicval 的值执行原子按位“and”,将结果存储回 atomic 中。

将此操作视为 { tmp = *atomic; *atomic &= val; return tmp; } 的原子版本。

此调用作为完整的编译器和硬件内存屏障。

虽然 atomic 有一个 volatile 限定符,但这是一个历史遗留问题,传递给它的指针不应该是 volatile

在 GLib 2.80 中,返回值类型已从 #gsize 变更为 #guintptr,以添加对具有 128 位指针的平台的支持。这不会影响现有代码。

自 2.30 起可用

参数

atomic

类型: void*

指向 gpointer 大小值的指针。

数据归函数调用方所有。
val

类型: gsize

“and”的值。

返回值

类型: guintptr

操作前 atomic 的值(无符号)。