栏目分类:
子分类:
返回
名师互学网用户登录
快速导航关闭
当前搜索
当前分类
子分类
实用工具
热门搜索
名师互学网 > IT > 软件开发 > 后端开发 > Java

Java中如何产生死锁呢?

Java 更新时间: 发布时间: IT归档 最新发布 模块sitemap 名妆网 法律咨询 聚返吧 英语巴士网 伯小乐 网商动力

Java中如何产生死锁呢?

下文笔者讲述Java中产生死锁的方法分享,如下所示

死锁的简介

死锁:
   多个线程互相阻塞,
   这里面一个线程或多个线程等待某个资源被释放,
   此时就会造成线程被无限期地阻塞,程序无法正常终止
   我们将这种现象称之为“死锁”

死锁产生的四个必要条件

1.某些线程间资源互斥使用,当某个资源被一个线程使用(占有)时,其他某个(或多个)线程不能使用
 2.不可抢占,资源请求者无法从别的线程中夺取资源
 3.请求和保持,线程请求资源后,再请求其他资源时,还未对原资料放弃持有
 4.循环等待,即存在一个等待队列:P1占有P2的资源,P2占有P3的资源,P3占有P1的资源。这样就形成了一个等待环路。
 当以上四个条件都成立时,此时就会产生死锁
package com.java265.other;
import java.util.Date;
public class Test16 {
	public static String obj1 = "java265.com-1";
	public static String obj2 = "java265.com-2";

	public static void main(String[] args) {
		LockA a = new LockA();
		new Thread(a).start();
		LockB b = new LockB();
		new Thread(b).start();
	}
}

class LockA implements Runnable {
	public void run() {
		try {
			System.out.println(new Date().toString() + " LockA 开始执行");
			while (true) {
				synchronized (Test16.obj1) {
					System.out.println(new Date().toString() + " LockA 锁住 obj1");
					Thread.sleep(3000); // 此处等待是给B能锁住机会
					synchronized (Test16.obj2) {
						System.out.println(new Date().toString() + " LockA 锁住 obj2");
						Thread.sleep(60 * 1000); // 为测试,占用了就不放
					}
				}
			}
		} catch (Exception e) {
			e.printStackTrace();
		}
	}
}

class LockB implements Runnable {
	public void run() {
		try {
			System.out.println(new Date().toString() + " LockB 开始执行");
			while (true) {
				synchronized (Test16.obj2) {
					System.out.println(new Date().toString() + " LockB 锁住 obj2");
					Thread.sleep(3000); // 此处等待是给A能锁住机会
					synchronized (Test16.obj1) {
						System.out.println(new Date().toString() + " LockB 锁住 obj1");
						Thread.sleep(60 * 1000); // 为测试,占用了就不放
					}
				}
			}
		} catch (Exception e) {
			e.printStackTrace();
		}
	}
}

转载请注明:文章转载自 www.mshxw.com
本文地址:https://www.mshxw.com/it/843038.html
我们一直用心在做
关于我们 文章归档 网站地图 联系我们

版权所有 (c)2021-2022 MSHXW.COM

ICP备案号:晋ICP备2021003244-6号