死锁实例

本文通过一个具体的Java代码示例,详细解析了死锁的发生条件及其原因。特别关注于线程同步机制中的wait和notify方法使用不当导致的问题。

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

下面这道题,是考死锁的,比较简单,想两个问题:

1.什么时候会造成死锁

2.wait和notify释放了哪个锁,因为题目中有两个锁。

 

import java.util.LinkedList;


public class DeadLockTest {
    LinkedList list = new LinkedList();  
      
    public synchronized void push(Object x) {  
        System.out.println("push");
        synchronized (list) {  
            list.addLast(x);  
            notify();  
        }  
    }  
 
    public synchronized Object pop() throws Exception {    
        synchronized (list) {  
            if (list.size() <= 0) {  
                wait();  
            }  
            return list.removeLast();  
        }  
    }  
    
    public static void main(String[] args) throws InterruptedException {
        final DeadLockTest deadLockTest = new DeadLockTest();
        Thread thread = new Thread(new Runnable() {
            public void run() {
                try {
                    deadLockTest.pop();
                } catch (Exception e) {
                    // TODO Auto-generated catch block
                    e.printStackTrace();
                }
            }
        });
        thread.start();
        Thread.sleep(2000);
        Thread threadPush = new Thread(new Runnable() {
            public void run() {
                try {
                    deadLockTest.push("push thread");
                } catch (Exception e) {
                    // TODO Auto-generated catch block
                    e.printStackTrace();
                }
            }
        });
        threadPush.start();
        
    }
}

 

显然当stack中没有元素时,pop的时候会释放this对象锁,当其它线程进行push或者pop时,list并没有释放,一直等待list的释放,但是wait又在等待其它线程唤醒,因此出现了死锁。

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值