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,
这样便形成了死锁。

猜你喜欢

转载自blog.csdn.net/qq_45273552/article/details/109085821