死锁:

概念:

所谓死锁: 是指两个或两个以上的进程在执行过程中,因争夺资源而造成的一种互相等待的现象,若无外力作用。它们都将无法推进下去。此时称系统处于死锁状态或系统产生了死锁,这些永远在互相等待的进程称为死锁进程。 因为资源占用是相互排斥的。当某个进程提出申请资源后。使得有关进程在无外力协助下,永远分配不到必需的资源而无法继续执行。这就产生了一种特殊现象:死锁。





死锁发生的条件:

1.相互排斥条件:一个资源每次仅仅能被一个线程使用

2.不可抢占条件(不剥夺条件):当前进程锁获得的资源,在未结束前,不能强行剥夺

3.占有且申请条件(请求与保持条件):一个进程已拥有一定的资源,又想申请别的资源,但对自己的资源又不放弃

4.循环条件:若干进程之间形成一种头尾相接的循环等待资源的关系





一般什么时候出现?  同步中嵌套同步

造一个死锁出来:

class Test2 implements Runnable
{
private boolean flag;
Test2(boolean flag )
{
this.flag = flag;
}
@Override
public void run()
{
// TODO Auto-generated method stub
if (flag)
{
synchronized (MyLock.locka)
{
System.out.println(Thread.currentThread().getName()+" if locka");
synchronized (MyLock.lockb)
{
System.out.println(Thread.currentThread().getName()+" if lockb");
}
}
}
else
{
synchronized (MyLock.lockb)
{
System.out.println(Thread.currentThread().getName()+" else lockb");
synchronized (MyLock.locka)
{
System.out.println(Thread.currentThread().getName()+" else locka");
}
}
}
}
} class MyLock
{
static Object locka = new Object();
static Object lockb = new Object();
} public class DieLockTest
{
public static void main(String[] args)
{
Thread t1 = new Thread(new Test2(true));
Thread t2 = new Thread(new Test2(false)); t1.start();
t2.start(); }
}

将之前验证同步函数的锁是this的程序也弄成死锁:

class Test1 implements Runnable
{
private static int num = 500;
Object obj = new Object();
boolean flag = true;
public void run ()
{
if (flag)
{
while (true)
{
synchronized (obj)//锁是obj
{
show ();//锁是this
}
}
}
else
{
while (true)
{
show();
}
}
}
public synchronized void show ()// 锁是 this
{
synchronized (obj)//锁是 obj
{
if (num >= 0)
{
try
{
Thread.sleep(20);
}
catch (Exception e)
{
// TODO: handle exception
System.out.println(e.toString());
}
System.out.println(Thread.currentThread().getName()+">>--code-- "+num--);
}
}
}
} public class DieLock
{
public static void main (String[] args)
{
Test1 t = new Test1();
Thread a = new Thread(t);
Thread b = new Thread(t); a.start();
try
{
Thread.sleep(20);
}
catch (Exception e)
{
// TODO: handle exception
}
t.flag = false;
b.start(); }
}

死锁的预防:

死锁的预防是保证系统不进入死锁状态的一种策略。

知道了死锁发生的条件,要避免死锁就要从打破条件入手。

点击打开链接

Java---16---多线程---死锁的更多相关文章

  1. java中多线程产生死锁的原因以及解决意见

    1.  java中导致死锁的原因 多个线程同时被阻塞,它们中的一个或者全部都在等待某个资源被释放,而该资源又被其他线程锁定,从而导致每一个线程都得等其它线程释放其锁定的资源,造成了所有线程都无法正常结 ...

  2. Java 多线程 - 死锁deadlock产生原因+避免方法

    ref: java中产生死锁的原因及如何避免 https://blog.csdn.net/m0_38126177/article/details/78587845 java如何避免死锁 http:// ...

  3. java多线程--死锁

    1. Java中导致死锁的原因 Java中死锁最简单的情况是,一个线程T1持有锁L1并且申请获得锁L2,而另一个线程T2持有锁L2并且申请获得锁L1,因为默认的锁申请操作都是阻塞的,所以线程T1和T2 ...

  4. 沉淀再出发:再谈java的多线程机制

    沉淀再出发:再谈java的多线程机制 一.前言 自从我们学习了操作系统之后,对于其中的线程和进程就有了非常深刻的理解,但是,我们可能在C,C++语言之中尝试过这些机制,并且做过相应的实验,但是对于ja ...

  5. java之多线程 二

    线程的生命周期: 当线程被创建并被启动时,它既不是一启动就进入了执行状态,在线程的生命周期中,它要经过new(新建),就绪(Runnable),运行(Running),阻塞(Blocked),dead ...

  6. Java的多线程机制系列:(一)总述及基础概念

    前言 这一系列多线程的文章,一方面是个人对Java现有的多线程机制的学习和记录,另一方面是希望能给不熟悉Java多线程机制.或有一定基础但理解还不够深的读者一个比较全面的介绍,旨在使读者对Java的多 ...

  7. Java基础--多线程的方方面面

    1,什么是线程?线程和进程的区别是什么? 2,什么是多线程?为什么设计多线程? 3,Java种多线程的实现方式是什么?有什么区别? 4,线程的状态控制有哪些方法? 5,线程安全.死锁和生产者--消费者 ...

  8. Java的多线程(上)

    多线程的优点和必要性是不言而喻的. 三种方法实现多线程 1. 继承Thread class A extends Thread{ public void run() {...} } 使用时, new A ...

  9. java复习-多线程

    和线程之间的关系: 进程:进程是程序的一次动态执行过程,他经理了代码加载,执行到执行完毕的一个完整过程,这个过程也是进程本身从产生,发展到最终消亡的过程. 线程:线程是实现并发机制的一种有效手段,进程 ...

  10. Java中多线程原理详解

    Java是少数的集中支持多线程的语言之一,大多数的语言智能运行单独的一个程序块,无法同时运行不同的多个程序块,Java的多线程机制弥补了这个缺憾,它可以让不同的程序块一起运行,这样可以让程序运行更加顺 ...

随机推荐

  1. 【干货】Linux内存数据的获取与转存 直捣密码

    知识源:Unit 2: Linux/Unix Acquisition 2.1 Linux/Unix Acquistion Memory Acquisition 中的实验demo部分  小白注意,这是网 ...

  2. mysql+mycat压力测试一例【转】

    前言 有很多人担心生产系统上新东西的程序怕压力跟不上和稳定性不行,是的,大家都怕,所以领导要求做一次压力测试,我个人也觉得是有必要的. 如果按原理来说,mycat如果不做分片,纯粹只是代理的话,他所做 ...

  3. 内存溢出(Memory Overflow)和内存泄露(Memory Leak)的区别

    内存泄漏指你用malloc或new申请了一块内存,但是没有通过free或delete将内存释放,导致这块内存一直处于占用状态 内存溢出指你申请了10个字节的空间,但是你在这个空间写入11或以上字节的数 ...

  4. list的几种new方式比较ImmutableList

    数组的非空判断: -----数组的非空判断----- StringUtils.isNotBlank(array); list的非空判断: -----list的非空判断----- CollectionU ...

  5. python之Anaconda版本管理

    首先安装Anaconda,当其安装成功后,可以在cmd中测试是否安装成功,conda --version conda的环境管理 Conda的环境管理功能允许我们同时安装若干不同版本的Python,并能 ...

  6. opencv的级联分类器(mac)

    级联分类器的介绍:级联分类器训练 因为要训练负样本,windows电脑有些问题,所以就只能有mac进行训练. 在windows中训练,准备了负样本之后,进行三步. 1.opencv_createsam ...

  7. linux文本编码格式转化 字幕处理

    在处理字幕的时候,linux的编码格式转换很烦. 步骤: 用python先判断 其编码,再用iconv 转编码,再用awk处理格式. file不能判断吗?file有时不准. 1.python判断编码 ...

  8. 2019 CCPC wannfly winter camp Day 8

    E - Souls-like Game 直接线段树合并矩阵会被卡T掉,因为修改的复杂度比询问的复杂度多一个log,所以我们考虑优化修改. 修改的瓶颈在于打lazy的时候, 所以我们预处理出每个修改矩阵 ...

  9. NAT虚拟网络配置

     NAT虚拟网络配置(Linux能上网) 1.先设置虚拟机的虚拟网络,设置里面的子网ip和网关ip地址: 有两种方式:①setup命令(不选DHCP,因为它是动态分配IP地址的) ②vi /etc/s ...

  10. rabbitMQ的安装(Windows下)

    在公司接触到这一块,信息中间件的使用,在公司没有时间了解的更加深入,只是在简单的使用,这里将深入学习一番. 参考:http://blog.csdn.net/lu1005287365/article/d ...