Volatile与synchronized的实现原理

1、Volatile

保证共享变量的“可见性”。当一个线程修改一个共享变量的时候,另一个线程能读到这个修改的值。

轻量级的synchronized,不会引起线程的上下文切换。

如果一个字段被生命为volatile,则java线程内存模型确保所有线程看到这个变量的值都是一致的。

2、synchronized

重量级锁。java中的每一个对象都可以作为锁。

当一个线程试图访问同步代码块时,它首先会得到锁,退出或者抛出异常时必须释放锁。


锁的四种状态:无锁状态、偏向锁状态、轻量级锁状态、重量级锁状态

优点缺点适用场景
偏向锁加锁和解锁不需要额外的消耗、和执行非同步方法相比仅存在纳秒级差距如果线程存在锁竞争、会带来额外的锁撤销的消耗适用于一个线程访问同步块的场景
轻量级锁竞争的线程不会阻塞、提高了程序的效应速度如果始终得不到锁竞争的线程,使用自旋消耗cpu追求响应时间、同步块执行速度非常快
重量级锁线程竞争不使用自旋,不会消耗cpu线程阻塞、响应时间缓慢追求吞吐量、同步块执行速度较长



评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值