多线程(Day22)

死锁

        概述

        死锁是指两个或两个以上的进程在执行过程中,由于竞争资源或由于彼此通信而造成的一种阻塞现象。若无外力作用,他们将无法进行下去,此时称系统处于死锁状态,这些永远在互相等待的进程称为死锁进程。

        原理

        1 某个线程执行完成,需要先后 嵌套锁定 两个对象,在这个过程中,先锁定了第一个对象 

        2 另一个线程执行完成也需要先后嵌套锁定两个对象,在这个过程中,先锁定了第二个对象

        3 第一个线程,执行中,要执行到第二个对象的时候,发现被锁定,进入等待状态,等待交出锁

        4 第二个线程执行中,要执行到第一个对象的时候,发现被锁定,进入等待状态

        5 此时两个线程都在等待对方交出锁,导致死锁

        代码实现

多线程(Day22)_第1张图片

多线程(Day22)_第2张图片

多线程(Day22)_第3张图片

 单例模式

        实现方式

多线程(Day22)_第4张图片

多线程(Day22)_第5张图片

 线程通信

        概述

        Object中的方法

        wait:让当前线程进入等待状态(挂起)并释放锁,当被唤醒之后,从接着挂起的位置继续执行。如果无参数,则不会自动醒来,需要唤醒。也可以传入Long类型的值,代表毫秒数,多久之后自动醒来。

        notify:唤醒一个在该对象中挂起的任意一个线程。

        notiAll:唤醒在该对象中挂起的所有线程。

        wait和sleep的区别

        wait:让当前线程进入挂起状态并解锁,必须加载在成员方法中。

        sleep:让当前线程进入睡眠状态,是静态方法,和是否加锁无关。如果在加锁方法中也不会释放锁。

        使用方式

多线程(Day22)_第6张图片

多线程(Day22)_第7张图片

多线程(Day22)_第8张图片

生产者和消费者 

        概念

        生产者消费者模式是通过一个容器来解决生产者和消费者的强耦合问题。生产者和消费者彼此之间不直接通讯,而通过阻塞队列来进行通讯,所以生产者生产完数据之后不用等待消费者处理,直接扔给阻塞队列,消费者不找生产者要数据,而是直接从阻塞队列里取,阻塞队列就相当于一个缓冲区,平衡了生产者和消费者的处理能力。

        这个阻塞队列就是用来给生产者和消费者解耦的。纵观大多数设计模式,都会找一个第三者出来进行解耦,如工厂模式的第三者是工厂类,模板模式的第三者是模板类。在学习一些设计模式的过程中,如果先找到这个模式的第三者,能帮助我们快速熟悉一个设计模式。

        模型 

多线程(Day22)_第9张图片

         使用方式

 

多线程(Day22)_第10张图片

多线程(Day22)_第11张图片

多线程(Day22)_第12张图片

多线程(Day22)_第13张图片

多线程(Day22)_第14张图片

 

 

 

 

 

 

 

你可能感兴趣的:(java,开发语言)