日韩av黄I国产麻豆传媒I国产91av视频在线观看I日韩一区二区三区在线看I美女国产在线I麻豆视频国产在线观看I成人黄色短片

歡迎訪問(wèn) 生活随笔!

生活随笔

當(dāng)前位置: 首頁(yè) >

C++ CAS 操作

發(fā)布時(shí)間:2024/3/24 51 豆豆
生活随笔 收集整理的這篇文章主要介紹了 C++ CAS 操作 小編覺(jué)得挺不錯(cuò)的,現(xiàn)在分享給大家,幫大家做個(gè)參考.

C++ 中的 CAS 操作用于操作原子變量,它是 atomic<T> 的成員函數(shù)。

#include <atomic>template <class T> struct atomic; bool compare_exchange_weak(T& expected, T val,memory_order sync = memory_order_seq_cst) volatile noexcept;

將當(dāng)前原子變量的內(nèi)容與 expected 相比較,

  • 如果兩者相等,則更新當(dāng)前原子變量的內(nèi)容為 val,并返回 true ;
  • 如果不相等,則將 expected 更新為當(dāng)前原子變量的內(nèi)容,并返回 false 。

需要注意的是:在進(jìn)行判等操作時(shí),它執(zhí)行的是物理上的比較,即直接比較內(nèi)存值,而不是使用 T 的 == 操作符進(jìn)行比較。

此外,它允許虛假失敗,也就是當(dāng)前原子變量的內(nèi)容與 expected 相等,但是它仍然返回 false ,但它不會(huì)修改 expected 。

它需要放在循環(huán)中使用。

如,

struct Node { int value; Node* next; }; std::atomic<Node*> list_head(nullptr);// 插入節(jié)點(diǎn)到表頭 void insert(int val) {Node* oldHead = list_head;Node* newNode = new Node{ val,oldHead };while (!list_head.compare_exchange_weak(oldHead, newNode)) {newNode->next = oldHead;} } bool compare_exchange_strong(T& expected, T val,memory_order sync = memory_order_seq_cst) volatile noexcept;

與 compare_exchange_weak() 大致相似,只是它不允許發(fā)生虛假失敗。

總結(jié)

以上是生活随笔為你收集整理的C++ CAS 操作的全部?jī)?nèi)容,希望文章能夠幫你解決所遇到的問(wèn)題。

如果覺(jué)得生活随笔網(wǎng)站內(nèi)容還不錯(cuò),歡迎將生活随笔推薦給好友。