1、避免一个线程同时获取多个锁

2、降低锁的使用粒度,尽量保证一个锁只占用一个资源

3、JDK提供的并发包提供的并发容器和工具类

4、尝试使用定时锁,使用lock.tryLock(timeout)来替代使用内部锁机制

5、对于数据库锁,加锁和解锁必须在一个数据库连接里,否则会出现解锁失败的情况

Logo

权威|前沿|技术|干货|国内首个API全生命周期开发者社区

更多推荐