博客
关于我
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/

    你可能感兴趣的文章
    Nmap扫描教程之Nmap基础知识
    查看>>
    nmap指纹识别要点以及又快又准之方法
    查看>>
    Nmap渗透测试指南之指纹识别与探测、伺机而动
    查看>>
    Nmap端口扫描工具Windows安装和命令大全(非常详细)零基础入门到精通,收藏这篇就够了
    查看>>
    NMAP网络扫描工具的安装与使用
    查看>>
    NMF(非负矩阵分解)
    查看>>
    nmon_x86_64_centos7工具如何使用
    查看>>
    NN&DL4.1 Deep L-layer neural network简介
    查看>>
    NN&DL4.3 Getting your matrix dimensions right
    查看>>
    NN&DL4.7 Parameters vs Hyperparameters
    查看>>
    NN&DL4.8 What does this have to do with the brain?
    查看>>
    nnU-Net 终极指南
    查看>>
    No 'Access-Control-Allow-Origin' header is present on the requested resource.
    查看>>
    NO 157 去掉禅道访问地址中的zentao
    查看>>
    no available service ‘default‘ found, please make sure registry config corre seata
    查看>>
    No compiler is provided in this environment. Perhaps you are running on a JRE rather than a JDK?
    查看>>
    no connection could be made because the target machine actively refused it.问题解决
    查看>>
    No Datastore Session bound to thread, and configuration does not allow creation of non-transactional
    查看>>
    No fallbackFactory instance of type class com.ruoyi---SpringCloud Alibaba_若依微服务框架改造---工作笔记005
    查看>>
    No Feign Client for loadBalancing defined. Did you forget to include spring-cloud-starter-loadbalanc
    查看>>