• CAS优缺点


    cas优点:如一描述在并发量不是很高时cas机制会提高效率。
    cas缺点:
    1、cpu开销大,在高并发下,许多线程,更新一变量,多次更新不成功,循环反复,给cpu带来大量压力。
    2、只是一个变量的原子性操作,不能保证代码块的原子性。
    3、ABA问题

    ABA问题:内存值V=100;
    threadA 将100,改为50;
    threadB 将100,改为50;
    threadC 将50,改为100;

    场景:小牛取款,由于机器不太好使,多点了几次全款操作。后台threadA和threadB工作,
    此时threadA操作成功(100->50),threadB阻塞。正好牛妈打款50元给小牛(50->100),
    threadC执行成功,之后threadB运行了,又改为(100->50)。
    牛气冲天,lz钱哪去了???

    如何解决aba问题:
    对内存中的值加个版本号,在比较的时候除了比较值还的比较版本号。

    java:AtomicStampedReference就是用版本号实现cas机制。

  • 相关阅读:
    ssh实现免密码登录和文件传输
    linux后台执行程序相关命令
    orchestrator
    curl下载安装与使用
    goland使用
    mysql集群
    consul理解
    my.cnf
    数据库的表设计
    项目常见面试问题
  • 原文地址:https://www.cnblogs.com/fengxf/p/10794177.html
Copyright © 2020-2023  润新知