1.场景:
----------------以下都是对象锁----------------------------------------------
Synchronized同步方法方法
1.关键字Synchronized取得的锁都是对象锁
2.多个线程去争抢同个对象锁的时候容易导致脏读
3.可重入锁:因为关键字取得的是对象锁,可以通过重入锁调用父类的同步方法:为什么呢,因为父类方法本来就是这个对象的。
4.出现异常的时候,锁会自动释放
5.同步不具有继承性
Synchronized同步语句块
1.为了解决同步方法可能导致的效率问题
2.访问synchronized(this)代码块的同时,访问其他synchronized(this)同步块和同步方法将被阻塞
3.解决2的问题是,使用synchronized(非this)来解决,防止不必要的阻塞
4.一般情况下不用String作为所对象,由于常量池缓存
----------------以下都是Class锁
Synchronized静态同步方法
Synchronized静态同步代码块
1.未Class锁,与对象锁不会产生阻塞
2.对所有实例都起作用
----------------以下为注意事项-----------------------------------------
1.查看死锁方法
用jps查看当前进程号
在用jstack -l id 查看具体情况
2.只要对象不变,及时对象的属性改变,对象锁还是同一个
--------------------------------------------------------------------------------
----------------以下都是对象锁----------------------------------------------
Synchronized同步方法方法
1.关键字Synchronized取得的锁都是对象锁
2.多个线程去争抢同个对象锁的时候容易导致脏读
3.可重入锁:因为关键字取得的是对象锁,可以通过重入锁调用父类的同步方法:为什么呢,因为父类方法本来就是这个对象的。
4.出现异常的时候,锁会自动释放
5.同步不具有继承性
Synchronized同步语句块
1.为了解决同步方法可能导致的效率问题
2.访问synchronized(this)代码块的同时,访问其他synchronized(this)同步块和同步方法将被阻塞
3.解决2的问题是,使用synchronized(非this)来解决,防止不必要的阻塞
4.一般情况下不用String作为所对象,由于常量池缓存
----------------以下都是Class锁
Synchronized静态同步方法
Synchronized静态同步代码块
1.未Class锁,与对象锁不会产生阻塞
2.对所有实例都起作用
----------------以下为注意事项-----------------------------------------
1.查看死锁方法
用jps查看当前进程号
在用jstack -l id 查看具体情况
2.只要对象不变,及时对象的属性改变,对象锁还是同一个
--------------------------------------------------------------------------------