【CAP】JAVA之AtomicReference非锁同步

并发最简单的竞态问题是操作一个基本变量,如一个整数。

复杂问题是同时操作多个变量,要保证变量的结果一致,比如A加1那B就要减1。

简单问题和复杂问题都可以通过锁来实现。

用锁划出临界区(一段代码),这段代码通过锁保证不能被并行执行。

代码就是对竞态数据的逻辑操作,并且只能通过这段代码操作竞态数据。

CAS提供了另一种解决竞态问题的方案。

AtomicReference解决竞态问题

比如A加1那B就要减1的问题,可以把A和B做成一个对象。

AtomicReference<AB> data = new AtomicReference<AB>();

每个线程复制一份data,操作完后通过compareAndSet设置到公共变量。

可以参考AtomicInteger加1的操作:

    public final int incrementAndGet() {
        for (;;) {
            int current = get();
            int next = current + 1;
            if (compareAndSet(current, next))
                return next;
        }
    }

可以封装个AtomicAB类来完成这件事,复制data到ThreadLocal中,修改完后再写加公共data对象。

http://iteedu.com/arch/cap/atomicrefer.htm
在这里插入图片描述

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值