Java并发小实验(二)假如霸道的join和谦让的yield人格相撞。。

这篇博客通过一个生动的“占着茅坑不拉屎”的比喻,探讨了Java并发编程中的死锁问题。代码示例展示了主线程与子线程在执行过程中可能出现的死锁情况,小明线程在执行到一半时无限期让出CPU,导致主线程无法继续执行。这种现象揭示了并发编程中同步和资源管理的复杂性,提醒开发者注意避免死锁的出现,确保程序的正常运行。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

这种行为,我们俗称“占着茅坑不拉屎”。。。

如果在插队的时候给别人让位置

public class Main implements Runnable{
	
	@Override
	public void run() {
		try {
			// 子线程先延时100ms,让主线程先跑,以保证多次实验的一致性。
			Thread.sleep(100);
		} catch (InterruptedException e) {
			e.printStackTrace();
		}
		for (int i = 0; i < 10; ++i) {
			System.out.println("我是" + Thread.currentThread().getName() + " -" + i);
			if (i == 4) {
				// 小明拿着插队证,执行到一半后,开始疯狂谦让,但是被插队的主线程敢怒不敢言。。
				// 于是,小明永远也无法把线程让出去,主线程也永远无法等到小明完成任务再继续自己的工作。。
				// 可能,这就是传说中的死锁吧~
				while (true){
					try {
						Thread.sleep(20);
					} catch (InterruptedException e) {
						e.printStackTrace();
					}
					Thread.yield();
				}
			}
		}
	}
	
	public static void main(String[] args) throws InterruptedException {
		
		Thread t1 = new Thread(new Main(), "小明");
		t1.start();
		for (int i = 0; i < 10; ++i) {
			System.out.println("我是主线程 -" + i);
			if (i == 4) {
				// 主线程执行到一半,小明来插队了。。
				t1.join();
			}
		}
	}
	
}
执行结果
我是主线程 -0
我是主线程 -1
我是主线程 -2
我是主线程 -3
我是主线程 -4
我是小明 -0
我是小明 -1
我是小明 -2
我是小明 -3
我是小明 -4
然后就一直阻塞着了。。。除非强制结束。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值