Volatile可见性验证,未出现死循环问题!!!

volatile的可见性

前言:由于JVM运行程序的实体是线程,而每个线程创建时JVM都会为其创建一个工作内存,工作内存是每个线程的私有数据区域,而Java内存模型中规定所有变量都是存储在主内存,主内存是共享内存区域,所有线程都可以访问,但线程对变量的操作(读取赋值等)必须在工作内存中进行,首先要将变量从主内存拷贝到自己的工作内存空间,然后对变量进行操作,操作完成后再将变量写回主内存,不能直接操作主内存中的变量,各个线程中的工作内存中存储着主内存中的变量副本拷贝,因此不同的线程无法访问对方的工作内存,线程间的通信(传值)必须通过主内存来完成。
定义: 当修改volatile变量时,会给cpu发送一个信号告诉其他cpu这个变量已修改,当其他cpu调用这个变量时,就会先检查是否有收到修改该变量的信号,有则重新从内存中读取。volatile是无锁的,类似于乐观锁的机制。

代码验证

/**
 * 1. 验证volatile的可见性
 * 1.1 加入 int  number = 0; number变量之前根本没有添加volatile关键字修饰
 */
public class VolatileDemo {
    public static void main(String[] args) {
        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.addTo60();
            System.out.println(Thread.currentThread().getName() + "\t update number value: " + myData.number);
        }, "thread_1").start();
        //第二个线程是我们的主线程
        while (myData.number == 0) {
            // main线程一直在这里等待循环,值到number的值不在等于0
        }
        System.out.println(Thread.currentThread().getName() + "\t mission is over, " +
                Thread.currentThread().getName() + "\t get number value: " + myData.number);
    }
}

class MyData {
    int number = 0;
    public void addTo60() {
        this.number = 60;
    }
}

问题:按照分析,应该出现主线线程无限循环的情况,但是并没有,会直接执行完成。更奇怪的是,用另一台笔记本又是正确的。

求解!!!!!!!!

尝试了很多次,不知道是什么问题,知道的大哥可以指教一下嘛!!!

华为的matebook不正确,雷神911正确

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 4
    评论
评论 4
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值