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

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

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+"获得口红");
        } 

    }
}
}

原文地址:https://blog.51cto.com/14437184/2429806

时间: 2024-10-09 06:57:06

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

Java多线程死锁避免方法

一.什么是死锁当两个或两个以上的线程在执行过程中,因为争夺资源而造成的一种相互等待的状态,由于存在一种环路的锁依赖关系而永远地等待下去,如果没有外部干涉,他们将永远等待下去,此时的这个状态称之为死锁.经典的 "哲学家进餐" 问题很好地描述了死锁状况:5个哲学家去吃中餐,坐在一张圆桌旁,他们有5根筷子(而不是5双),并且每两个人中间放一根筷子,哲学家们要么在思考,要么在进餐,每个人都需要一双筷子才能吃到东西,并在吃完后将筷子放回原处继续思考,有些筷子管理算法 (1) 能够使每个人都能相对

java 多线程死锁问题

什么是死锁 所谓死锁: 是指两个或两个以上的进程在执行过程中,因争夺资源而造成的一种互相等待的现象,若无外力作用,它们都将无法推进下去. 死锁产生的原因及条件 那么为什么会产生死锁呢? 1.因为系统资源不足. 2.进程运行推进的顺序不合适. 3.资源分配不当. 学过操作系统的朋友都知道:产生死锁的条件有四个: 1.互斥条件:所谓互斥就是进程在某一时间内独占资源. 2.请求与保持条件:一个进程因请求资源而阻塞时,对已获得的资源保持不放. 3.不剥夺条件:进程已获得资源,在末使用完之前,不能强行剥夺

java多线程死锁

原文链接 作者:Jakob Jenkov 译者:申章 校对:丁一 java中死锁是两个或更多线程阻塞着等待其它处于死锁状态的线程所持有的锁.死锁通常发生在多个线程同时但以不同的顺序请求同一组锁的时候. 例如,如果线程1锁住了A,然后尝试对B进行加锁,同时线程2已经锁住了B,接着尝试对A进行加锁,这时死锁就发生了.线程1永远得不到B,线程2也永远得不到A,并且它们永远也不会知道发生了这样的事情.为了得到彼此的对象(A和B),它们将永远阻塞下去.这种情况就是一个死锁. 该情况如下: Thread 1

Java 程序死锁问题原理及解决方案

本文已经于2015年8月24日发表于IBM开发者论坛 Java 语言通过 synchronized 关键字来保证原子性,这是因为每一个 Object 都有一个隐含的锁,这个也称作监视器对象.在进入 synchronized 之前自动获取此内部锁,而一旦离开此方式,无论是完成或者中断都会自动释放锁.显然这是一个独占锁,每个锁请求之间是互斥的.相对于众多高级锁 (Lock/ReadWriteLock 等),synchronized 的代价都比后者要高.但是 synchronzied 的语法比较简单,

java多线程----死锁

什么叫死锁?所谓死锁: 是指两个或两个以上的进程在执行过程中,因争夺资源而造成的一种互相等待的现象,若无外力作用,它们都将无法推进下去.    那么为什么会产生死锁呢?1.因为系统资源不足.2.进程运行推进的顺序不合适.    3.资源分配不当.             学过操作系统的朋友都知道:产生死锁的条件有四个:1.互斥条件:所谓互斥就是进程在某一时间内独占资源.2.请求与保持条件:一个进程因请求资源而阻塞时,对已获得的资源保持不放.3.不剥夺条件:进程已获得资源,在末使用完之前,不能强行

Java多线程死锁的产生实例

死锁产生的四个必要条件: (1) 互斥条件:一个资源每次只能被一个进程使用.(2) 请求与保持条件:一个进程因请求资源而阻塞时,对已获得的资源保持不放.(3) 不剥夺条件:进程已获得的资源,在末使用完之前,不能强行剥夺.(4) 循环等待条件:若干进程之间形成一种头尾相接的循环等待资源关系. 示例:死锁实例 package cn.thread.lock; public class ThreadLock implements Runnable{ private static Object o1=ne

java 多线程死锁

死锁案例: package com.test; public class DealThread implements Runnable { public String username; public Object lock1 = new Object(); public Object lock2 = new Object(); public void setFlag(String username) { this.username = username; } @Override public

关于java多线程死锁的实验

先上完整的代码 后续再依次修改代码块得到相应的结论 1 //尝试写一个死锁 感受一下 2 public class DeadLock { 3 public static void main(String[] args) { 4 Object o1 = new Object(); 5 Object o2 = new Object(); 6 //创建两个object对象 7 //创建两个Thread线程 8 Thread T1 = new Thread(new process1(o1,o2)); /

Java多线程:死锁

周末看到一个用jstack查看死锁的例子.昨天晚上总结了一下jstack(查看线程).jmap(查看内存)和jstat(性能分析)命令.供大家参考 1.Jstack 1.1   jstack能得到运行java程序的java stack和native stack的信息.可以轻松得知当前线程的运行情况.如下图所示  注:这个和thread dump是同样的结果.但是thread dump是用kill -3 pid命令,还是服务器上面少用kill为妙 1.2   命名行格式 jstack [ opti