当前位置: 首页 > news >正文

网站搭建系列教程网站设计方法

网站搭建系列教程,网站设计方法,金华网站建设多少钱,网站建设款计入什么科目文章目录 原子操作之compare_exchange_strong1 简介2 核心2 语法3 与 compare_exchange_weak的区别4 使用场景示例4.1 无锁计数器4.2 线程安全栈(Treiber Stack) 5 内存序(Memory Order)参数6 关键注意事项7 总结 原子操作之compa…

文章目录

  • 原子操作之compare_exchange_strong
    • 1 简介
    • 2 核心
    • 2 语法
    • 3 与 compare_exchange_weak的区别
    • 4 使用场景示例
      • 4.1 无锁计数器
      • 4.2 线程安全栈(Treiber Stack)
    • 5 内存序(Memory Order)参数
    • 6 关键注意事项
    • 7 总结

原子操作之compare_exchange_strong

1 简介

std::atomic 类型提供的一个关键原子操作.
作用:

  1. 实现无锁(lock-free)编程中的 比较并交换(Compare-and-Swap, CAS)
  2. 确保在多线程环境中安全地修改共享数据,避免竞态条件(race condition)。

2 核心

  1. 比较并交换

    • 输入参数
      • expected:期望的旧值(引用传递,操作后可能被修改)。
      • desired:希望设置的新值。
      • memory_order:内存序(可选,默认 std::memory_order_seq_cst)。
    • 操作逻辑
      • 如果原子变量的当前值等于 expected,则将其设置为 desired,并返回 true
      • 如果当前值不等于 expected,则将 expected 更新为当前值,并返回 false
  2. 原子性保证

    • 整个操作是原子的,不会被其他线程中断。

2 语法

bool compare_exchange_strong(T& expected, T desired,std::memory_order order = std::memory_order_seq_cst
);

3 与 compare_exchange_weak的区别

特性compare_exchange_strongcompare_exchange_weak
伪失败永远不会伪失败(总是严格的 CAS)允许在某些平台返回伪失败(即使值匹配)
适用场景需要确保操作成功的一次性场景循环中重试的场景(如自旋锁)
性能可能略低(需严格检查)可能更高(允许硬件优化)
典型代码模式单次检查(如无锁队列的精确条件)循环重试(如 while (!weak(...))

4 使用场景示例

4.1 无锁计数器

std::atomic<int> counter{0};void increment() {int old_val = counter.load();while (true) {int new_val = old_val + 1;if (counter.compare_exchange_strong(old_val, new_val)) {break; // 成功递增}// 失败时 old_val 已更新为当前值,继续重试}
}

4.2 线程安全栈(Treiber Stack)

template<typename T>
class LockFreeStack {struct Node {T data;Node* next;};std::atomic<Node*> head{nullptr};public:void push(const T& value) {Node* new_node = new Node{value, head.load()};while (!head.compare_exchange_strong(new_node->next, new_node));}bool pop(T& value) {Node* old_head = head.load();while (old_head && !head.compare_exchange_strong(old_head, old_head->next)) {}if (!old_head) return false;value = old_head->data;delete old_head;return true;}
};

5 内存序(Memory Order)参数

compare_exchange_strong 接受以下内存序(控制操作的原子性和可见性):

  • std::memory_order_relaxed:无同步(仅保证原子性)。
  • std::memory_order_acquire:当前线程的后续读操作必须在此操作后执行。
  • std::memory_order_release:当前线程的前序写操作必须在此操作前完成。
  • std::memory_order_acq_rel:结合 acquirerelease
  • std::memory_order_seq_cst:全局顺序一致性(默认,性能最低)。

6 关键注意事项

  1. ABA 问题

    • 如果 expected 值在操作期间被其他线程修改为其他值后又改回原值,compare_exchange_strong 会误认为值未变。
    • 解决方案:使用带版本号的原子变量(如 std::atomic<std::pair<T, uint64_t>>)或 hazard pointer
  2. 循环重试

    • 在冲突激烈时,compare_exchange_strong 可能导致忙等待(busy-wait),需结合退避策略(如指数退避)。
  3. 性能优化

    • 在循环中使用 compare_exchange_weak 更高效(如自旋锁),而 compare_exchange_strong 适合单次检查。

7 总结

compare_exchange_strong 是 C++ 无锁编程的核心工具,通过严格的 CAS 语义保证线程安全。使用时需结合内存序参数、循环重试机制,并警惕 ABA 问题。在需要精确条件判断时优先使用 strong 版本,而在循环中可优先使用 weak 版本以提升性能。

http://www.dtcms.com/a/547395.html

相关文章:

  • 产品网站建设广州哪里可以做网站
  • 有关网站建设的参考书wordpress减压完成后
  • 网站更换空间需要怎么做网站设计常见问题
  • 青岛网站建设找微网站 底部导航菜单
  • 网站前端开发培训招聘网页制作课程设计
  • 网站怎么开发代码免费留电话号码的广告
  • 上海网站制作公司价格
  • 免费凡科建站官网服务一流的做网站
  • 做外贸哪个网站最好wordpress 回到首页
  • 现代化专业群建设专题网站护理专业会所网站建设
  • 空气过滤棉上海网站建设建设银行租房平台网站6
  • 个人网站做推广wordpress源码整合
  • 网站制作费用预算表网站排名突然掉没了
  • 公司开发的网站微信网站入口
  • 深圳荷坳网站建设公司个人备案做公司网站
  • wordpress制作培训网站安全网站建设情况
  • 靖江网站制作多少钱为什么要创建网站子目录
  • 东营区建设局网站做网站怎么选服务器
  • 交互设计主要做什么乐山网站seo
  • 友情链接平台站长资源重庆江北网站建设公司
  • 微网站 方案市场营销案例分析及解答
  • 网站建设中最重要的建立网站需要多少人
  • 网站建设维护考试湘潭自助建站系统
  • asp.net 网站修改发布wordpress 引入文件
  • 网站建设成都公司哪家好给公司做宣传网站的好处
  • 韩国网站做暧暖爱视频每一刻网站
  • wordpress建站成品图中国水利建设网站
  • 自己怎么做网站免费的东莞做企业宣传网站
  • 网站建设 app开发网站如何加强省市网站建设
  • 佛山做网站建设公司ip网站查询服务器