线程死锁的简单案例

class DeadLock extends Thread{

    //新建两个对象锁
    static String str1 = new String();
    static String str2 = new String();
    public void run() {

        //创建同步代码块
        synchronized(str1){

            //打印线程刚获取对象锁的状态信息
            System.out.println(Thread.currentThread().getName()+"已经占有了str1");
            try {
                //让线程t1睡眠5秒,使得线程t2有足够的时间占有str1
                Thread.sleep(3000);
            } catch (InterruptedException e) {
                // TODO: handle exception
                e.printStackTrace();
            }
            
            System.out.println(Thread.currentThread().getName()+"试图占有str2");
            System.out.println(Thread.currentThread().getName()+"等待中...");
            //该线程第二次访问同步代码块,并释放两个对象锁
            synchronized(str2){
                System.out.println(Thread.currentThread().getName()+"已经占有str1和str2");
            }
        }
    }
}  

 //新建一个子类继承DeadLock,代码内容与上面基本相同

class DeadLock2 extends DeadLock{
    public void run(){
        synchronized(str2){
            System.out.println(Thread.currentThread().getName()+"已经占有str2");
            try{
                Thread.sleep(3000);
            }catch (InterruptedException e) {
                // TODO: handle exception
                e.printStackTrace();
            }
            System.out.println(Thread.currentThread().getName()+"试图占有str1");
            System.out.println(Thread.currentThread().getName()+"等待中...");
            synchronized(str1){
                System.out.println(Thread.currentThread().getName()+"已经占有了str2和str1");
            }
        }
    }
}
    /*
     * 当两个线程t1和t2试图同时占有str1和str2的时候,程序会停止造成死锁
     */


public class Thread_Deadlock {
    public static void main(String[] args){
        DeadLock d1 = new DeadLock();

        //命名线程为t1
        d1.setName("t1");
        d1.start();
        
        DeadLock2 d2 = new DeadLock2();

       //命名线程t2
        d2.setName("t2");
        d2.start();
    }
}

 

运行的结果为:

t2已经占有str2
t1已经占有了str1
t2试图占有str1
t2等待中...
t1试图占有str2
t1等待中...

 

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值