资讯

精准传达 • 有效沟通

从品牌网站建设到网络营销策划,从策略到执行的一站式服务

java多线程-死锁的产生以及解决方案

死锁:
过多的同步造成相互不释放资源,从而过多地等待,一般发生于
同步中持有多个对象的锁

潮州ssl适用于网站、小程序/APP、API接口等需要进行数据传输应用场景,ssl证书未来市场广阔!成为创新互联公司的ssl证书销售渠道,可以享受市场价格4-6折优惠!如果有意向欢迎电话联系或者加微信:18982081108(备注:SSL证书合作)期待与您的合作!

snchronized锁住对象同时,另一个snchronized就不能锁该对象
避免在一个代码块中,同时持有多个对象的锁

死锁:

public class tt {

public static void main(String[]args)
{
    markup m1=new markup(1,"me");
    markup m2 =new markup(2,"she");
    m1.start();
    m2.start();
}
}

//口红
class lipstick{

}

//镜子
class mirror{

}

//化妆
class markup extends Thread{
//加静态表示一份,不管创建几个对象都是一份
static lipstick lip=new lipstick();
static mirror mir=new mirror();

//选择
int choice;
String girl;

public markup(int choice,String girl)
{
    this.choice=choice;
    this.girl=girl;
}

public void run(){

    mark();
}
//相互持有对方的对象锁-->可能造成死锁
//加等待时间是为了让另一个线程锁相同对象的时候,该线程
//锁的相同对象还没有结束
//在这个死锁中,第一个线程内的mir要等第二个已经开始的mir锁结束才能执行
//而第二个线程内的mir结束需要等第一个线程内的lip解锁才行
private void mark()
{
    if(choice==0)
    {
        synchronized(lip)
        {
            System.out.println(this.girl+"获得口红");
            //一秒后想要镜子
            try {
                Thread.sleep(1000);
            } catch (InterruptedException e) {
                // TODO Auto-generated catch block
                e.printStackTrace();
            }
            synchronized(mir)
            {
                System.out.println(this.girl+"获得镜子");
            } 

        }

    }else
    {
        synchronized(mir)
        {
            System.out.println(this.girl+"获得镜子");
            //2秒后想要口红
            try {
                Thread.sleep(2000);
            } catch (InterruptedException e) {
                // TODO Auto-generated catch block
                e.printStackTrace();
            }
        synchronized(lip)
            {
                System.out.println(this.girl+"获得口红");
            } 
        }

    }
}
}

解决:

public class tt {

public static void main(String[]args)
{
    markup m1=new markup(1,"me");
    markup m2 =new markup(2,"she");
    m1.start();
    m2.start();
}
}

//口红
class lipstick{

}

//镜子
class mirror{

}

//化妆
class markup extends Thread{
//加静态表示一份,不管创建几个对象都是一份
static lipstick lip=new lipstick();
static mirror mir=new mirror();

//选择
int choice;
String girl;

public markup(int choice,String girl)
{
    this.choice=choice;
    this.girl=girl;
}

public void run(){

    mark();
}
{
    if(choice==0)
    {
        synchronized(lip)
        {
            System.out.println(this.girl+"获得口红");
            //一秒后想要镜子
            try {
                Thread.sleep(1000);
            } catch (InterruptedException e) {
                // TODO Auto-generated catch block
                e.printStackTrace();
            }
        }
        synchronized(mir)
        {
            System.out.println(this.girl+"获得镜子");
        } 

    }else
    {
        synchronized(mir)
        {
            System.out.println(this.girl+"获得镜子");
            //2秒后想要口红
            try {
                Thread.sleep(2000);
            } catch (InterruptedException e) {
                // TODO Auto-generated catch block
                e.printStackTrace();
            }

        }
        synchronized(lip)
        {
            System.out.println(this.girl+"获得口红");
        } 

    }
}
}

本文标题:java多线程-死锁的产生以及解决方案
标题网址:http://cdkjz.cn/article/gpdcse.html
多年建站经验

多一份参考,总有益处

联系快上网,免费获得专属《策划方案》及报价

咨询相关问题或预约面谈,可以通过以下方式与我们联系

大客户专线   成都:13518219792   座机:028-86922220