1锁粗化:为了保证多线程间的有效并发,会要求每个线程持有锁的时间尽量的短。只有这样,等待在这个锁的其他线程才能尽早的获取公共资源执行任务。但是频繁的对同一个锁不断的请求,同步 和释放也是很消耗资源的。这样性能反而会下降。因此,虚拟机在遇到连续对锁的请求的时候,会把多次请求合并和一次请求,从而减少对锁的请求同步次数,这叫做锁粗化。例如在循环体内用了sync关键字。
2自旋锁:在并发时,不断的挂起和回复线程会带来频繁的线程上下文切换,尤其是对共享资源仅占用极短的时候,锁的等待只需要很短的时间,可能比线程上下文切换的时间还短,这种情况下可以使用自旋锁。说白了就是在对锁竞争不激烈的时候使用自旋锁。
3锁销除:虚拟机在运行时,基于逃逸分析技术,捕获到不可能存在竞争,但是又申请锁的时候,会消除这些不必要的锁。
4偏向锁:记录最近一次获取到锁的线程ID,当该线程再次请求锁的时候,无需进行相关同步操作。、
关于偏向锁的加锁以及解锁过程:
加锁:1首先查看markWord是否是偏向锁,如果是偏向锁,查看当前线程ID是否是自己,如果是,则获取到锁,执行同步代码,如果不是则自旋获取锁。
2自旋获取锁,如果成功,则执行同步代码,如果失败,说明有锁竞争,持有偏向锁的线程到达全区安全点的时候被挂起,偏向锁升级成轻量级锁。然后阻塞在安全点的线程继续执行。
解锁:偏向锁的释放,只有当有线程竞争锁,才会释放。偏向锁的释放需要到达全局安全点,首先查看持有锁的线程是否处于活动状态,如果不是则标记为无锁。如果处于活动状态则遍历栈中的锁记录(可能标记为不适合偏向锁,可能标记为无锁,可能重新偏向别的线程)