专栏首页软件开发-青出于蓝AtomicInteger之实现简析 原

AtomicInteger之实现简析 原

1. getAndSet(int newValue)

    它调用的是unsafe的getAndSetInt,如下List-1,不断的循环比较,而后设置结果。会阻塞,一直到设置完成。

List-1

    public final int getAndSetInt(Object var1, long var2, int var4) {
        int var5;
        do {
            var5 = this.getIntVolatile(var1, var2);
        } while(!this.compareAndSwapInt(var1, var2, var5, var4));

        return var5;
    }

2. compareAndSet(int expect, int update)

    它调用的直接就是unsafe的compareAndSwapInt,这个方法不会阻塞调用,会立即返回,根据返回的boolean结果来判断是否成功

List-2

    public final boolean compareAndSet(int expect, int update) {
        return unsafe.compareAndSwapInt(this, valueOffset, expect, update);
    }

3. weakCompareAndSet(int expect, int update)

    它的实现与compareAndSet一样,如下:

List-3

    public final boolean weakCompareAndSet(int expect, int update) {
        return unsafe.compareAndSwapInt(this, valueOffset, expect, update);
    }

4. lazySet(int newValue)

    它的实现如下

List-4

    public final void lazySet(int newValue) {
        unsafe.putOrderedInt(this, valueOffset, newValue);
    }

5. getAndIncrement、getAndDecrement

    如下

List-5

    public final int getAndIncrement() {
        return unsafe.getAndAddInt(this, valueOffset, 1);
    }

List-6

    public final int getAndDecrement() {
        return unsafe.getAndAddInt(this, valueOffset, -1);
    }

    unsafe的getAndAddInt的实现如下List-7:

List-7

    public final int getAndAddInt(Object var1, long var2, int var4) {
        int var5;
        do {
            var5 = this.getIntVolatile(var1, var2);
        } while(!this.compareAndSwapInt(var1, var2, var5, var5 + var4));

        return var5;
    }

    为什么AtomicInteger中的value有volatile修饰?这是由于有多个线程并发修改它,为了保证多线程之间的可见性。

    为什么AtomicBoolean中的value是int类型,而不是boolean类型,见https://stackoverflow.com/questions/13724858/why-java-util-concurrent-atomic-atomicboolean-is-internally-implemented-with-int ,感觉也没有真正的说清楚。

问题:

unsafe的compareAndSwapInt,底层上是如何实现的,它是native方法

unsafe的putOrderedInt,底层上是如何实现的,它是native方法

openjdk6的unsafe.cpp文件:http://hg.openjdk.java.net/jdk6/jdk6/hotspot/file/4fc084dac61e/src/share/vm/prims/unsafe.cpp

openjdk7的unsafe.cpp文件:http://hg.openjdk.java.net/jdk7/jdk7/hotspot/file/4fc084dac61e/src/share/vm/prims/unsafe.cpp

openjdk8的unsafe.cpp文件:http://hg.openjdk.java.net/jdk8u/jdk8u60/hotspot/file/37240c1019fd/src/share/vm/prims/unsafe.cpp

(adsbygoogle = window.adsbygoogle || []).push({});

本文参与腾讯云自媒体分享计划,欢迎正在阅读的你也加入,一起分享。

我来说两句

0 条评论
登录 后参与评论

相关文章

  • ubuntu上从mysql中用命令行备份出数据库

    参考:http://blog.csdn.net/xundh/article/details/46275195

    克虏伯
  • SpringFramework之DefaultAdvisorChainFactory

        JdkDynamicAopProxy中使用到了拦截器链,如下List-1,advised是ProxyFactory,而方法getInterceptors...

    克虏伯
  • Springsecurity之AuthenticationProvider

        注意:AuthenticationProvider与Authentication紧密联系,关于Authentication,看我的这篇博客。

    克虏伯
  • POJ 刷题系列:1503 Integer Inquiry

    POJ 刷题系列:1503 Integer Inquiry 传送门:POJ 1503 Integer Inquiry 题意: 实现VeryLongIntege...

    用户1147447
  • 2240. Arbitrage

    思路: 在图模型中找负环即可。此处符合负环的特征如下:在负环上的顶点会不断更新最大值,所以在N轮没有停止更新就说明存在了负环。

    用户1147447
  • tkinter -- Scrollbar

    Scrollbar(滚动条),可以单独使用,但最多的还是与其它控件(Listbox,Text,Canva 等)结合使用

    py3study
  • 【CV学习2.2】 倒数与梯度

    EdenChen
  • POJ 刷题系列:2159. Ancient Cipher

    POJ 刷题系列:2159. Ancient Cipher 传送门:POJ 2159. Ancient Cipher 题意: 给定两个长度相等的字符串a, b...

    用户1147447
  • POJ 刷题系列:2262. Goldbach's Conjecture

    POJ 刷题系列:2262. Goldbach’s Conjecture 传送门:POJ 2262. Goldbach’s Conjecture 题意: 给定...

    用户1147447
  • POJ 刷题系列:2388. Who's in the Middle

    版权声明:本文为博主原创文章,未经博主允许不得转载。 https://blog.csdn.net/...

    用户1147447

扫码关注云+社区

领取腾讯云代金券