1、避免一个线程同时获取多个锁
2、降低锁的使用粒度,尽量保证一个锁只占用一个资源
3、JDK提供的并发包提供的并发容器和工具类
4、尝试使用定时锁,使用lock.tryLock(timeout)来替代使用内部锁机制
5、对于数据库锁,加锁和解锁必须在一个数据库连接里,否则会出现解锁失败的情况
1、避免一个线程同时获取多个锁
2、降低锁的使用粒度,尽量保证一个锁只占用一个资源
3、JDK提供的并发包提供的并发容器和工具类
4、尝试使用定时锁,使用lock.tryLock(timeout)来替代使用内部锁机制
5、对于数据库锁,加锁和解锁必须在一个数据库连接里,否则会出现解锁失败的情况