多线程_死锁问题概述和使用

64 篇文章 0 订阅
45 篇文章 0 订阅
package cn.itcast_02;

/*
 * 同步的弊端:
 * 		A:效率低
 * 		B:容易产生死锁
 * 
 * 死锁:
 * 		两个或者两个以上的线程在争夺资源的过程中,发生的一种相互等待的现象。
 * 
 * 举例:
 * 		中国人,美国人吃饭案便。
 * 		正常情况:
 * 			中国人:筷子2支
 * 			美国人:刀和叉
 * 		现在:
 * 			中国人:筷子1支,刀1把
 * 			美国人:筷子1支,叉1把
 */
public class DieLockDemo {
	public static void main(String[] args) {
		// 创建线程对象
		DieLock dl1 = new DieLock(true);
		DieLock dl2 = new DieLock(false);

		// 启动线程
		dl1.start();
		dl2.start();
	}
}


package cn.itcast_02;

public class MyLock {
	// 创建两把锁对象
	public static final Object objA = new Object();
	public static final Object objB = new Object();
}


package cn.itcast_02;

public class DieLock extends Thread {
	private boolean flag;

	public DieLock(boolean flag) {
		this.flag = flag;
	}

	@Override
	public void run() {
		if (flag) {
			synchronized (MyLock.objA) {
				System.out.println("if objA");
				synchronized (MyLock.objB) {
					System.out.println("if objB");
				}
			}
		} else {
			synchronized (MyLock.objB) {
				System.out.println("else objB");
				synchronized (MyLock.objA) {
					System.out.println("else objA");
				}
			}
		}
	}
}


评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值