- 偏向锁 思想:若某一锁被线程获取后,便进入偏向模式,当线程再次请求这个锁是,无需再进行相关的同步操作,从而节省了操作时间。 偏向锁使用于竞争不激烈的情况,在竞争激烈的情况下,会导致持有锁的线程不停地切换,锁也很难一直保持在偏向模式,此时,不仅得不到性能的优化,反而有可能降低系统性能。
- 轻量级锁 如果偏向锁失败,Java虚拟机会让线程申请轻量级锁。
- 锁膨胀 当轻量级锁失败,虚拟机就会使用重量级锁。
- 自旋锁 自旋锁可以使线程在没有取得锁时,不被挂起,而转而去执行一个空虚幻(即所谓的自旋),在若干个空循环后,线程如果可以获得锁,则继续执行。若线程依然不能获得锁,才会被挂起。 注意:适用于竞争不激烈的情况下,对于锁竞争激烈,单线程锁占用时间长的并发程序,自旋锁在自旋等待后,往往依然无法获得对应的锁,不仅仅拜拜浪费了CPU时间,最终还是免不了执行被挂起的操作,反而浪费了系统资源。
- 锁消除 锁消除是Java虚拟机在JIT编译时,通过对运行上下文的扫描,去除不可能存在共享资源竞争的锁。通过锁消除,可以节省毫无意义的请求锁时间。比如,开发人员在没有锁竞争的代码中用了JDK内置的线程安全类:StringBuffer,Vector等。
锁在java虚拟机中的实现和优化
最新推荐文章于 2021-03-22 21:50:41 发布