一个多线程死锁案例,如何避免及解决死锁问题?

多线程死锁在java程序员笔试的时候时有遇见,死锁概念在之前的文章有介绍,大家应该也都明白它的概念,不清楚的去翻看历史文章吧。

下面是一个多线程死锁的例子

输出

thread1 get lock1

thread2 get lock2

两个线程相互得到锁1,锁2,然后线程1等待线程2释放锁2,线程2等待线程1释放锁1,两者各不相互,这样形成死锁。

那么如何避免和解决死锁问题呢?

  • 1、按顺序加锁

上个例子线程间加锁的顺序各不一致,导致死锁,如果每个线程都按同一个的加锁顺序这样就不会出现死锁。

  • 2、获取锁时限

每个获取锁的时候加上个时限,如果超过某个时间就放弃获取锁之类的。

  • 3、死锁检测

按线程间获取锁的关系检测线程间是否发生死锁,如果发生死锁就执行一定的策略,如终断线程或回滚操作等。


本文的重点是你有没有收获与成长,其余的都不重要,希望读者们能谨记这一点。同时我经过多年的收藏目前也算收集到了一套完整的学习资料,包括但不限于:分布式架构、高可扩展、高性能、高并发、Jvm性能调优、Spring,MyBatis,Nginx源码分析,Redis,ActiveMQ、、Mycat、Netty、Kafka、Mysql、Zookeeper、Tomcat、Docker、Dubbo、Nginx等多个知识点高级进阶干货,希望对想成为架构师的朋友有一定的参考和帮助
需要更详细思维导图和以下资料的可以加一下技术交流分享群:“708 701 457”免费获取



扫描二维码关注公众号,回复: 6141056 查看本文章

猜你喜欢

转载自blog.csdn.net/qq_42982923/article/details/89678066
今日推荐