volatile與JMM內存模型

volatile是輕量級的同步機制:
  • 保證可見性
  • 不保證原子性
  • 禁止指令重排
JMM(Java Memory Model)Java內存模型

三大特性:

  • 可見性
  • 原子性
  • 有序性
    JMM內存模型之可見性
import java.util.concurrent.TimeUnit;
import java.util.concurrent.atomic.AtomicInteger;

public class VolatileDemo {

    public static void main(String[] args) {
        //seeOk();
        atomicTest();
    }

    /**
     * volatile保證可見性
     */
    public static void seeOk(){
        Mydata my = new Mydata();
        System.out.println(Thread.currentThread().getName()+"初始值:"+my.num);

        new Thread(()->{
            try {
                TimeUnit.SECONDS.sleep(3);
            } catch (InterruptedException e) {
                e.printStackTrace();
            }
            my.addTo60();
            System.out.println(Thread.currentThread().getName()+"3秒後的值:"+my.num);
        },"other thread").start();
        while(my.num==0){
			//等於0時不再繼續往下執行
        }
        System.out.println(Thread.currentThread().getName()+"mission is over:"+my.num);
    }

    /**
     * volatile不保證原子性
     */
    public static void atomicTest(){
        Mydata data = new Mydata();
        for(int i=0;i<20;i++){
            new Thread(()->{
                for(int j=0;j<1000;j++){
                    data.addPlusPlus();
                    data.addAtomic();
                }
            }).start();
        }
        while(Thread.activeCount()>2){
            Thread.yield();
        }
        System.out.println(Thread.currentThread().getName()+":int  "+data.num);
        System.out.println(Thread.currentThread().getName()+":AtomicInteger  "+data.atomicInteger);
    }
}

class Mydata{
    volatile int num = 0;
    AtomicInteger atomicInteger = new AtomicInteger();

    public void addTo60(){
        this.num = 60;
    }
    public void addPlusPlus(){
        num++;
    }

    public void addAtomic(){
        atomicInteger.getAndIncrement();
    }
}
發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章