文章目录
synchronized特性
-
互斥
当某个线程执行到某个对象的synchronized中时,其他线程如果也执行到同一个对象的synchronized就会阻塞等待。
进入synchronized修饰的代码块相当于加锁
退出synchronized修饰的代码块相当于解锁
-
刷新内存
synchronized的工作过程:
1.获得互斥锁
2.从主内存拷贝变量的最新版本到工作内存
3.执行代码
4.将更改后的变量值刷新到主内存
5.释放互斥锁
-
可重入
同一把锁,连续加锁两次,不会导致死锁,那么它就是可重入的。
synchronized原理
锁升级/锁膨胀
解释:
synchronized更多的考虑到降低程序员的使用负担,内部就实现了"自适应"的操作。这个"自适应"的操作就是"锁升级/锁膨胀"
如果当前程序中,锁竞争不激烈,则以轻量级锁的状态来工作。可以第一时间拿到锁。
如果当前程序中,锁竞争很激烈,则以重量级锁的状态来工作。减少CPU的开销。
偏向锁是什么呢?
锁消除
由JVM自动判断,如果它发现某个地方的代码不需要加锁,但是你写了synchronized,它就会自动把锁给去掉。
比如:多个线程修改多个不同的变量时,你对它们分别加锁
注: JVM只有在100%确定这处代码的加锁可以去掉时才会执行锁消除操作,就算有1%的可能这儿不能去掉也不会锁消除。
锁粗化
锁的粒度,就是指:synchronized包含的代码块里代码的多少
粒度粗:包含的代码多
粒度细:包含的代码少
锁粗化,就是:把粒度细的锁合并为粒度粗的锁。这样可以减少加锁和解锁的开销。
注:
- 对同一个对象的加锁才能进行锁粗化
- 锁粗化要保证粗化前和粗化后,代码的逻辑不变