*阿炮的Java笔记016号*-简说volatile关键字和原子性

62 阅读1分钟

老生常谈…对于大佬们根本都不用看的博客!

对于像我这种菜鸡还是得一步一步的来!如果有错误请大佬们指点指点!

volatile

简介

当线程 A 修改了共享数据的时候,B 线程没有及时获取到最新的数据,如果还在使用原先的数据,就会出现问题。 这该怎么办呢?

然后volatile 关键字就会强制线程在每次使用的时候,都会看一下共享区域最新的数据。

当然也可以用synchronized的方法(例如火车票问题),我们今天介绍的时volatile ,废话不多说直接上代码:

public class TestVolatile {
    static class Money {
        public static volatile int money = 10;
    }
    static class Me extends Thread{

        @Override
        public void run() {
            while (Money.money == 10){
                System.out.println("我还有十块钱!");
            }
            System.out.println("我的钱没了!");
        }
    }
    static class You extends Thread{

        @Override
        public void run() {
            try {
                Thread.sleep(50);
            } catch (InterruptedException e) {
                e.printStackTrace();
            }
            Money.money = 0;
            System.out.println("借点钱!");
        }
    }

    public static void main(String[] args) {
        Me me = new Me();
        You you = new You();
        me.start();
        you.start();
    }
}

原子性

简介

原子性指的是一次操作或多次操作,要么所有的操作都会成功,要么所有的操作都不成功。

volatile 关键字只能保证每次使用共享数据的时候是最新值,但是不能保证原子性。

atomic类能够保证原子性。

synchronized 和 CAS 的区别

  • 相同点:在多线程的情况下,都可以保证共享数据的安全性。
  • 不同点:synchronized是悲观锁,CAS是乐观锁。