前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >AtomicMarkableReference源码解析

AtomicMarkableReference源码解析

作者头像
写一点笔记
发布2020-08-25 14:20:18
4190
发布2020-08-25 14:20:18
举报
文章被收录于专栏:程序员备忘录程序员备忘录

之前在说CAS的时候说过ABA问题,ABA问题就是在多线程情况下,其他线程修改了共享变量,但最终共享变量的值并没有发生变化。以至于当前线程无法辨别共享变量是否已经发生了变化。为了使得线程之间能够判断共享变量是否被其他线程修改,办法就是给在操作共享变量的时候添加标识。通过判断这个标识来判断是否共享变量被其他线程修改了。在java的JUC工具包中,提供了两种方式来对ABA问题进行解决,其中一类是判断共享变量是否中途被其他线程修改,采用的是布尔变量的方式。另一种是采用int类型的变量,从而使得CAS的判断条件更加灵活,也更加适合实际情况。下面分别介绍这两种方式。

AtomicMarkableReference

上边的程序简单的表达了AtomicMarkableReference的使用方式。下边我们看看AtomicMarkableReference的源码设计

首先是volatile变量pair,AtomicMarkableReference通过内部类的方式将pair进行封装,采用T变量的模式兼容所有类型的数据,在pair中有变量mark,mark就是用来判断数据是否被修改的判断标志。

由于pair是volative修饰的,因此所有的对数据的读操作均采用pair。

在进行设置值的时候,采用我们熟悉的compareAndSet方法。首先判断旧的值和新的值是否相同,并判断mark的标志是否相同。如果数据均未发生变化,那么就不执行set,否则采用casPair方法进行赋值操作。

在casPair方法中,直接采用sun提供的Unsafe进行CAS操作。但是首先我们要明白的是,pairOffset的意义,由于在我们实类化时候采用真实的是AtomicMarkableReference,也就是说我们的数据实际上是位于AtomicMarkableReference对象中的pair中,因此这里在AtomicMarkableReference初始化的时候获取pair中其中的内存偏移量。从而在小范围内进行CAS自旋赋值。

本文参与 腾讯云自媒体分享计划,分享自微信公众号。
原始发表:2020-05-21,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 程序员备忘录 微信公众号,前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体分享计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档