- 首先,我们先谈谈死锁的概念:死锁就是在多线程并发中,一个线程需要用到其他线程的锁,但自己也占用的其他线程的锁,就比如线程一有两把锁,锁A和锁B,线程二也有两把锁,顺序是锁B和锁A,此时线程一占用锁A,在请求锁B时发现已被锁二占用,而线程二请求A进入等待,两个线程都进入等待而陷入死循环。
- 在来谈一下造成死锁的原因
- 资源不能共享,只能被一个进程或线程占用;
- 已经被占用的资源不能被剥夺;
- 已经锁定的资源不能共享;
- 循环等待;
- 如何解决
- 尽量避免并发出现修改的语句;
- 避免事务处理时间过长;
- 将经常进行修改的数据库与进场查询的数据分离开来;
- 再进行修改时将涉及到的数据全部上锁;
- 事物的上锁顺序保持一致。
本文详细解释了死锁的概念及成因,包括资源独占、不可剥夺等,并提出了避免并发修改、缩短事务处理时间等解决方案。
1万+

被折叠的 条评论
为什么被折叠?



