Python 官方文档:入门教程 => 点击学习
目录1、死锁产生的条件 2、模拟多线程环境下死锁的产生3、死锁的排查 1、死锁产生的条件 互斥:一次只有一个进程可以使用一个资源。其他进程不能访问已分配给其他进程的资源。
注意:前三个条件都只是死锁存在的必要条件,但不是充分条件。第四个条件是充分条件。以上条件同样适用于线程。
public class DeadLock {
// 模拟两个资源
public static Object lock1 = new Object();
public static Object lock2 = new Object();
// 先申请lock1资源,再去申请lock2资源
public static void getLock1First(){
synchronized (lock1){
System.out.println("getlock1");
getLock2();
}
}
public static void getLock2(){
synchronized (lock2) {
System.out.println("lock1->lock2");
}
}
// 先申请lock2资源,再申请lock1资源
public static void getlock2First(){
synchronized (lock2){
System.out.println("getlock2");
getLock1();
}
}
public static void getLock1(){
synchronized (lock1){
System.out.println("lock2->lock1");
}
}
public static void main(String[] args) {
new Thread(){
@Override
public void run() {
// 太难把控线程运行的时机了 也有可能此线程执行完了lock1->lock2的顺序
// 直接死循环一直运行
// 总会刚好遇到线程1刚好获得lock1,线程2刚好获得lock2
while (true){
getLock1First();
}
}
}.start();
new Thread(){
@Override
public void run() {
while (true){
getlock2First();
}
}
}.start();
}
}
死锁:
先进入jdk安装的bin目录,启动命令行,输入命令jps查看运行的线程ID
死锁检测1:
执行jstack -l 线程ID命令
死锁检测2:
可以看到Thread-1
和Thread-2
都在相互等待对方持有的对象的monitor
锁释放。
到此这篇关于Java多线程环境下死锁模拟的文章就介绍到这了,更多相关Java多线程死锁模拟内容请搜索编程网以前的文章或继续浏览下面的相关文章希望大家以后多多支持编程网!
--结束END--
本文标题: Java多线程环境下死锁模拟
本文链接: https://www.lsjlt.com/news/159705.html(转载时请注明来源链接)
有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341
下载Word文档到电脑,方便收藏和打印~
2024-03-01
2024-03-01
2024-03-01
2024-02-29
2024-02-29
2024-02-29
2024-02-29
2024-02-29
2024-02-29
2024-02-29
回答
回答
回答
回答
回答
回答
回答
回答
回答
回答
0