Volatile与synchronized的实现原理

1、Volatile

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

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

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

2、synchronized

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

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


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

扫描二维码关注公众号,回复: 2079556 查看本文章

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



猜你喜欢

转载自blog.csdn.net/Efforts_To_Advanced/article/details/80982390