volatile的作用和syncornized的区别

本文通过代码示例探讨了volatile关键字在多线程环境中的作用,揭示其如何解决线程间的可见性问题,同时对比了volatile与synchronized在确保数据可见性和原子性方面的差异。volatile仅能保证变量的可见性,不保证原子性,而synchronized则提供了更全面的线程同步机制。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

这个是面试高频题

首先上代码看一下volatile的作用
public class JMMTest {

      private boolean flag = false;
    public static void main(String[] args) throws Exception {
        final JMMTest jmmTest = new JMMTest();
        //实现Runable接口 使用匿名内部类简化代码
       new Thread(new Runnable() {
           @Override
           public void run() {
               System.out.println("thread1--start");
               while (!jmmTest.flag){
               }
               System.out.println("thread1--end");
           }
       }).start();
       Thread.sleep(100);
       new Thread(new Runnable() {
           @Override
           public void run() {
               System.out.println("thread2--start");
               jmmTest.flag=true;
               System.out.println("thead2---end");
           }
       }).start();
    }
}

 

上面代码的运行结果是

线程1无法感知到看到线程2对共享变量flag的改变,所以!jmmTest.flag一直是初始值true,所以就无限的循环

当给变量falg加上valotile关键字的时候运行结果是这样的

说明在加volatile之后线程1就能感知到看到线程2对共享变量的改变,然而进行相关的判断操作

 

结论

    //主内存中  解决不同线程之间的可见性   缓存一致性协议   缓存一致性问题  总线嗅探机制的监听

    //1   lock指令 汇编指令
    //2   强制修改的值写入主内存
    //3   当写操作的时候,其它线程对应的cpu缓存暂时失效

volatile的作用和syncornized的区别主要有两点

1:valotile只能作用于变量,而syncornized可以作用于变量和方法

2:volitle只能保证数据的可见性,不能保证原子性,syncornized既可以保证数据的可见性,在多线程下还可以保证原子性(即原子性)

 

 

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值