首页 > 编程语言 > 详细

java 线程问题,写一个死锁(原理:只有互相都等待对方放弃资源才会产生死锁)

时间:2018-01-19 19:11:31      阅读:206      评论:0      收藏:0      [点我收藏+]
package com.swift;

public class DeadLock implements Runnable {
    private boolean flag;

    DeadLock(boolean flag) {
        this.flag = flag;
    }

    public void run() {
        while (true) {
            if (flag) {
                synchronized ("suo1") {
                    System.out.println(Thread.currentThread().getName()+"if....locka");
                    synchronized ("suo2") {
                        System.out.println(Thread.currentThread().getName()+"if.....lockb");
                    }
                }
            } else {
                synchronized ("suo2") {
                    System.out.println(Thread.currentThread().getName()+"else.....lockb");
                    synchronized ("suo1") {
                        System.out.println(Thread.currentThread().getName()+"else....locka");
                    }
                }
            }
        }
    }

    public static void main(String[] args) {
        
        /*
         * 写一个死锁
         */
        //只有互相都等待对方放弃资源才会产生死锁
        new Thread(new DeadLock(true),"线程1").start();
        new Thread(new DeadLock(false),"线程2").start();
    }
}

同步代码块的锁也可以用对象,如LockA.locka

locka对象为静态 公共

java 线程问题,写一个死锁(原理:只有互相都等待对方放弃资源才会产生死锁)

原文:https://www.cnblogs.com/qingyundian/p/8318367.html

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!