Java多线程之浅谈死锁问题

Java多线程之浅谈死锁问题

死锁是java多线程中的一个重要内容,对于死锁的理解相当重要。

什么是死锁:
板正的官方定义为:
当多个线程分别占用其他线程所需要的同步资源,都在等待其他线程释放自己所需要的同步资源时,就形成了死锁。
这样的例子我们并不太好理解,请看如下的例子:
在这里插入图片描述

如上图,a,b两个小人,面前的桌上有一张桌子和两碗饭,但只有一双筷子,那么问题来了,每个人只能在有一双筷子的情况下才能吃饭,也就是a先拿筷子吃,再把筷子都给b,这样两人都能顺利的吃完饭。
那么死锁是什么情况呢?就是a拿着一支筷子,b拿着一支筷子,两人谁都不给谁,那么,就会一直僵持着,谁都吃不了饭。

死锁出现后的现象:
死锁后:不会出现异常,也不会出现提示,只是所有的线程都会处于阻塞状态,无法继续。

下面我们用java代码来演示一下死锁的出现:

public class deadLock {
	public static void main(String[] args) {
		StringBuffer s1=new StringBuffer();
		StringBuffer s2=new StringBuffer();
		 new Thread() {
			 @Override
			public void run() {
				// TODO Auto-generated method stub
				synchronized(s1) {
					s1.append("a");
					s2.append("1");
					
					try {
						sleep(1000);
					} catch (InterruptedException e) {
						// TODO Auto-generated catch block
						e.printStackTrace();
					}
					
					synchronized(s2) {
						s1.append("b");
						s2.append("2");
						System.out.println(s1);
						System.out.println(s2);
					}
				}
			}
		 }.start();
		 
		 new Thread(new Runnable() {
			 @Override
			public void run() {
				// TODO Auto-generated method stub
				synchronized(s2) {
					s1.append("c");
					s2.append("3");
					
					try {
						Thread.sleep(1000);
					} catch (InterruptedException e) {
						// TODO Auto-generated catch block
						e.printStackTrace();
					}
					
					synchronized(s1) {
						s1.append("d");
						s2.append("4");
						System.out.println(s1);
						System.out.println(s2);
					}
				}
			}
		 }).start();
	}
}

运行后会发现并不会有输出,
这是因为我们使用了synchronized同步代码块,
首先定义的StringBuffer是线程安全的。s1,s2就是临界资源
线程一拿着s1的锁去要s2,
而线程二拿着s2的锁去要s1,
这样便形成了死锁。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值