volatile 可见性代码验证

volatile保证可见性,什么是可见性?

 

程序:

让A线程修改number变量,在main线程用while一直循环,直到A线程修改,然后打印 “main线程结束” 结束程序。

public class VolatileTest {

    public static void main(String[] args) {
        MyTest myTest = new MyTest();
        new Thread(new Runnable() {
            @Override
            public void run() {
                System.out.println("进入A线程");
                try {
                    //等3秒
                    Thread.sleep(3000);
                } catch (InterruptedException e) {
                    e.printStackTrace();
                }
                //调用方法 赋值 60
                myTest.addTo60();
                System.out.println(Thread.currentThread().getName()+" :  "+myTest.number);
            }
        },"A线程").start();

        //如果读到A线程number为0,一直循环
        while (myTest.number == 0){
        }

        System.out.println("main线程结束");
    }
}

class MyTest{

    int number = 0;

    public void addTo60(){
        this.number = 60;
    }

}

控制台结果:

当A线程从主存拿到数据,然后再自己的工作内存中操作数据(修改为60),然后刷新到主存。

程序一直不结束,此处我们可以知道,main线程没有去主存拿新的数据,一直读不到   60,所以没有保证可见性。

 

在number变量前面加上volatile,再次来看效果

volatile保证可见性 

这里给number变量加上volatile后,当A线程修改number之后,刷新到主存,main线程去主存拿到新的数据,然后停止。

什么是可见性?

通俗来讲,当一个线程修改共享数据,其它线程立刻接到修改的通知,修改后的数据对其它线程可见。

  • 1
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
原语的原子是指对于某个操作,要么它完全执行成功,要么完全不执行,没有中间状态。原语的原子可以确保在多线程环境中,对共享资源的操作不会出现竞态条件(Race Condition)等并发问题。 在单机环境下,可以通过以下方式实现原语的原子: 1. 使用互斥锁(Mutex):在需要保证原子代码块或操作前后使用互斥锁,确保同一时间只有一个线程可以访问该代码块或操作。互斥锁可以通过系统调用或者编程语言提供的库函数来实现。 2. 使用原子操作指令:一些处理器提供了针对共享内存的原子操作指令,如比较并交换(Compare and Swap,CAS)等。这些指令在硬件层面上保证了操作的原子。 在实现原语的原子时,需要注意以下问题: 1. 正确:确保原语的实现逻辑正确,不会引入潜在的逻辑错误。例如,在使用互斥锁时,需要注意加锁和解锁的位置是否正确,避免死锁和解锁未加锁的情况。 2. 能:选择合适的原子实现方式以及合理地粒度划分。过细粒度的锁或原子操作可能会导致能下降,而过粗粒度可能无法发挥并发能优势。 3. 可见:在多线程环境中,保证共享资源的可见,即一个线程对共享资源的修改能够被其他线程正确地读取到。可以通过使用适当的内存屏障(Memory Barrier)或者使用volatile等机制来实现可见。 4. 死锁和饥饿:在使用互斥锁时,需要注意避免死锁和饥饿的问题。死锁是指多个线程相互等待对方释放锁的情况,饥饿是指某个线程长时间无法获取到锁的情况。 总之,在实现原语的原子时,需要综合考虑正确能、可见以及避免死锁和饥饿等问题。选择合适的实现方式,并进行充分的测试和验证,以确保原语的原子在多线程环境下能够正常工作。
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值