1.死锁死锁是这样一种情形:多个线程同时被阻塞,它们中的一个或者全部都在等待某个资源被释放。由于线程被无限期地阻塞,因此程序不可能正常终止。Java 死锁产生的四个必要条件:互斥使用,即当资源被一个线程使用(占有)时,别的线程不能使用不可抢
1.死锁
死锁是这样一种情形:多个线程同时被阻塞,它们中的一个或者全部都在等待某个资源被释放。由于线程被无限期地阻塞,因此程序不可能正常终止。
Java 死锁产生的四个必要条件:
互斥使用,即当资源被一个线程使用(占有)时,别的线程不能使用
不可抢占,资源请求者不能强制从资源占有者手中夺取资源,资源只能由资源占有者主动释放。
请求和保持,即当资源请求者在请求其他的资源的同时保持对原有资源的占有。
循环等待,即存在一个等待队列:P1占有P2的资源,P2占有P3的资源,P3占有P1的资源。这样就形成了一个等待环路。
当上述四个条件都成立的时候,便形成死锁。当然,死锁的情况下如果打破上述任何一个条件,便可让死锁消失。
2.模拟一个死锁
package com.tl.skyLine.thread; import java.util.Date; public class DeadLock { public static String bowl = "碗"; public static String chopsticks = "筷子"; public static void main(String[] args) { LockA la = new LockA(); new Thread(la).start(); LockB lb = new LockB(); new Thread(lb).start(); } } class LockA implements Runnable { public void run() { try { System.out.println(new Date().toString() + "邹保健开始拿餐具吃饭"); while (true) { synchronized (DeadLock.bowl) { System.out.println(new Date().toString() + "邹保健抢到了碗"); Thread.sleep(3000); // 此处等待是给B能锁住机会 synchronized (DeadLock.chopsticks) { System.out.println(new Date().toString() + "邹保健抢到了筷子"); Thread.sleep(60 * 1000); // 为测试,占用了就不放 } } } } catch (Exception e) { e.printStackTrace(); } } } class LockB implements Runnable { public void run() { try { System.out.println(new Date().toString() + "陈顶天开始拿餐具吃饭"); while (true) { synchronized (DeadLock.chopsticks) { System.out.println(new Date().toString() + "陈顶天抢到了筷子"); Thread.sleep(3000); // 此处等待是给A能锁住机会 synchronized (DeadLock.bowl) { System.out.println(new Date().toString() + "陈顶天抢到了碗"); Thread.sleep(60 * 1000); // 为测试,占用了就不放 } } } } catch (Exception e) { e.printStackTrace(); } } }
--结束END--
本文标题: java多线程学习之死锁的模拟和避免(实例讲解)
本文链接: https://www.lsjlt.com/news/225261.html(转载时请注明来源链接)
有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341
下载Word文档到电脑,方便收藏和打印~
2024-05-16
2024-05-16
2024-05-16
2024-05-16
2024-05-16
2024-05-16
2024-05-16
2024-05-16
2024-05-16
2024-05-16
回答
回答
回答
回答
回答
回答
回答
回答
回答
回答
0