您当前的位置: 首页 >  Java

java持续实践

暂无认证

  • 2浏览

    0关注

    746博文

    0收益

  • 0浏览

    0点赞

    0打赏

    0留言

私信
关注
热门博文

Java多线程 volatile 介绍与不适用的场景

java持续实践 发布时间:2020-09-06 10:33:55 ,浏览量:2

文章目录
      • volatile介绍
      • volatile 不适用的场景

volatile介绍

volatile是一种同步机制, 比synchronized 或者Lock 更轻量级, 因为使用volatile 并不会发生上下文切换等开销很大的行为. 仅仅是把值刷入主内存中, 和从主内存中读取值.

如果一个变量被修饰成volatile , 那么JVM就这个了这个变量可能会被并发修改.

由于volatile 开销小, 因此相应的并发能力也小, 虽然volatile 是用来同步保证线程安全性的, 但是volatile不能做到synchronized 那样的原子保护, volatile仅仅在很有限的场景下才能发挥作用 .

volatile 不适用的场景

不适用于a++的情况

如下的代码演示了 volatile 不适用于a++的场景. 起了两个线程, 对a进行++操作 ,并且 a用 volatile 修饰. 并且用AtomicInteger 统计实际的执行次数

package com.thread.jmm;

import java.util.concurrent.atomic.AtomicInteger;

/**
 * 类名称:IncorrectVolatile
 * 类描述:volatile 不适用的场景
 *
 * @author: https://javaweixin6.blog.csdn.net/
 * 创建时间:2020/9/6 10:08
 * Version 1.0
 */
public class IncorrectVolatile implements Runnable {
    volatile int a = 0;

    //原子类, 统计执行了多少次
    AtomicInteger atomicInteger = new AtomicInteger();

    public static void main(String[] args) throws InterruptedException {
        IncorrectVolatile runnable = new IncorrectVolatile();
        Thread thread1 = new Thread(runnable);
        Thread thread2 = new Thread(runnable);

        thread1.start();
        thread2.start();

        //主线程等待子线程执行完毕
        thread1.join();
        thread2.join();

        System.out.println("a++的结果: "+runnable.a);
        System.out.println("运行a++的次数 : "+runnable.atomicInteger.get());
    }

    @Override
    public void run() {
        for (int i = 0; i             
关注
打赏
1658054974
查看更多评论
0.0408s