博客
关于我
CAS原理
阅读量:606 次
发布时间:2019-03-12

本文共 752 字,大约阅读时间需要 2 分钟。

最终优化后的文章

什么是CAS

CAS是比较与交换的一种并发控制算法,用于处理并发问题。它通过比较内存值V与预期值E,然后在两者匹配时将V设为新值B。若不匹配,则无改动。这种机制高效且弱锁,能避免死锁。

CAS理解

CAS包含三个操作数:V(变量)、E(预期值)、B(新值)。当且仅当V等于E时,执行V=B。其他情况不变。这种设计使得CAS具有原子性和非阻力。

CAS步骤

CAS操作假设自己能成功,并认为自己是最终获取成功的线程。当多线程执行时,如果多线程使用一个变量,只有一个线程会成功更新,其他线程失败。此失败不会阻塞线程,线程继续尝试或放弃。

CAS优势
  • 优雅替代锁:无需复杂的锁结构。
  • 性能优势:无锁机制,性能远超锁,降低系统开销。
  • 不防御死锁:更高并发制约点下的更优选择。
  • 常用语言中的实现

    Java中的AtomicLong实现了CAS,简单易用。其背后依赖CPU支持的原子指令,确保线性时间复杂度。其他语言如C/C++也有类似机制,通过INTERlocked和-exchanging指令实现。

    CAS案例

    编写一个简单案例观察CAS行为。创建多个线程同时修改共享变量,通过日志记录每次操作结果。发现行为是否符合预期,列举成功与失败情况。

    ABA问题

    使用带版本号的原子引用,如AtomicStampedReference来解决ABA问题。当变量的值冲突,通过记录版本号确保正确性。

    总结

    理解CAS需要手头案例和持续实践。通过观察日志,发现潜在问题,如ABA冲突。学会使用高级工具如带版本号的原子引用来完善实现,确保正确性。案例展示实用性,巩固理解。

    小彩蛋

    调试工具如Visual Studio Code能帮助识别线程问题,选择正确的调试模式确保数据流正确。是一种直观的方式调试并发问题。

    转载地址:http://bzwaz.baihongyu.com/

    你可能感兴趣的文章
    No mapping found for HTTP request with URI [/...] in DispatcherServlet with name ...的解决方法
    查看>>
    No mapping found for HTTP request with URI [/logout.do] in DispatcherServlet with name 'springmvc'
    查看>>
    No module named 'crispy_forms'等使用pycharm开发
    查看>>
    No module named cv2
    查看>>
    No module named tensorboard.main在安装tensorboardX的时候遇到的问题
    查看>>
    No module named ‘MySQLdb‘错误解决No module named ‘MySQLdb‘错误解决
    查看>>
    No new migrations found. Your system is up-to-date.
    查看>>
    No qualifying bean of type XXX found for dependency XXX.
    查看>>
    No resource identifier found for attribute 'srcCompat' in package的解决办法
    查看>>
    no session found for current thread
    查看>>
    No toolchains found in the NDK toolchains folder for ABI with prefix: mips64el-linux-android
    查看>>
    NO.23 ZenTaoPHP目录结构
    查看>>
    no1
    查看>>
    NO32 网络层次及OSI7层模型--TCP三次握手四次断开--子网划分
    查看>>
    NoClassDefFoundError: org/springframework/boot/context/properties/ConfigurationBeanFactoryMetadata
    查看>>
    Node JS: < 一> 初识Node JS
    查看>>
    Node Sass does not yet support your current environment: Windows 64-bit with Unsupported runtime(72)
    查看>>
    Node-RED中使用JSON数据建立web网站
    查看>>
    Node-RED中使用json节点解析JSON数据
    查看>>
    Node-RED中使用node-random节点来实现随机数在折线图中显示
    查看>>