案例讲解原子性、可见性

虽然自己明白什么是原子性,什么是可见性。但今天有空余时间,所以就当是加强理解。
实例:

public class MyData {

    //当我们对变量添加Volatile的时候将会看见其可见性
    volatile int number = 0;
    public void aVoid(){
        this.number=60;
    }
//不添加synchronized就不能保证原子性,因为Volatile不保证原子性
    public synchronized void  addNumber(){
        number++;
    }
}

/**
 * 原子性
 * 不可分割,完整性,
 * 也即是某个线程在做摸个业务时,中间不可以被加塞或则分割。
 * 需要整体完整,要么同时成功,要么同时失败。
 */
class VolatileDemo{
    public static void main(String[] args) {
       MyData myData = new MyData();
       for (int i =1;i<=20; i++){
           new Thread(()->{
               for (int j= 1;j<=1000; j++){
                   myData.addNumber();
               }

           },String.valueOf(i)).start();
       }
       while (Thread.activeCount()>2){
           Thread.yield();
       }
        System.out.println(Thread.currentThread().getName()+"\t finally number"+myData.number);
    }
    
    //可见性
    private static void seeByVolatile() {
        MyData myData = new MyData();
        new Thread(()->{
            System.out.println(Thread.currentThread().getName()+"\t come in");
            try {
                TimeUnit.SECONDS.sleep(3);
            }catch (InterruptedException e){
                e.printStackTrace();
            }
            myData.aVoid();
            System.out.println(Thread.currentThread().getName()+"\t update number value"+myData.number);
        },"AAA").start();

        while (myData.number==0){
            //没有可见性的情况将会死循环
        }
        System.out.println(Thread.currentThread().getName()+"\t mission is over");
    }
}
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值