线程 —————— 死锁

当两个线程同时需要访问两个量时,两人各执一个,即,线程之间相互限制访问而导致程序无法运行

instance 1:

public class TestDeadlock implements Runnable{
	public int flag = 0;
	static Object o1 = new Object();
	static Object o2 = new Object();
	
	public void run() {
		System.out.println("flag =" + flag);
		if(flag == 0) {
			synchronized(o1) {
				try {
					Thread.sleep(1000);
				} catch (InterruptedException e) {
					e.printStackTrace();
				}
				synchronized(o2) {
					System.out.println("hello");
				}
			}
		}
		if(flag == 1) {
			synchronized(o2) {
				try {
					Thread.sleep(2000);
				} catch (InterruptedException e) {
					e.printStackTrace();
				}
				synchronized(o1) {
					System.out.println("beybey");
				}
			}
		}
	}
	
	public static void main(String[] args) {
		TestDeadlock t1 = new TestDeadlock();
		TestDeadlock t2 = new TestDeadlock();
		t1.flag = 1;
		t2.flag = 0;
		Thread m1 = new Thread(t1);
		Thread m2 = new Thread(t2);
		m1.start();
		m2.start();
	}

}

在上面可以发现在flag为1和flag为0的情况下都要求锁住o1和o2所以当两个线程同时运行的时候就会出现两个各占一个object,而导致都无法运行,

注:当object 不是static方法时,不会出现死锁现象,只有当其为static后才会出现。如果不用static修饰,运行两次就会产生自己各自的对象,也就不会出现死锁的问题。

 

 

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值