Synchronized学习
1 原理
依赖jvm实现同步,底层是通过一个监视器对象(monitor)完成。wait()、notify()等方法也依赖monitor对象
其中监视器锁(monitor)的本质依赖于底层操作系统的互斥锁(Mutex Lock)实现
2 作用
保证同一时刻最多只有一个线程执行被Synchronized修饰的方法/代码,其他线程必须等待当前线程执行结束释放锁后方可获取锁执行,以此来保证线程安全
3 场景
修饰实例方法/代码块,(同步)保护的是同一个对象方法的调用&当前实例对象
修饰静态方法,(同步)保护的还是静态方法的调用&calss对象
4 核心思想
- 一把锁只能同时被一个线程获取,没有拿到锁的线程必须等待,属于悲观锁
- 每个实例都对应自己的一把锁,不同实例之间互不影响。例外:所对象是*.class或者Synchronized修饰的是static方法时,所有对象都公用同一把锁
- 正常运行完毕或者抛出异常都会释放锁
5 性质
- 可重入性:同一线程外层函数获取锁后,内层函数可以直接再次获取该锁,避免死锁,提高封装性。
- 不可中断性:一旦锁被别的线程获取,本线程就必须等待或者阻塞,直到别的线程释放锁,如果永不释放锁,本线程就永久等待
6 缺点
- 效率低:锁的释放情况少,试图获得所的时候不能设置超时,不能中断一个正在试图获得锁的线程
- 不够灵活:加锁和释放锁的时机单一,每个锁仅有单一的条件,可能是不够的,无法知道是否成功获取到锁