多线程(Day22)

死锁

概述

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

原理

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

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

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

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

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

代码实现

单例模式

实现方式

线程通信

概述

Object中的方法

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

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

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

wait和sleep的区别

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

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

使用方式

生产者和消费者

概念

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

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

模型

使用方式

相关推荐
cheryl882 分钟前
Python+Requests 企业级接口测试入门(1~3天)
开发语言·python
Spring-wind6 分钟前
【golang】为什么协程开销小于线程
java·开发语言·golang
Yang-Never12 分钟前
Open GL ES -> SurfaceView + 自定义EGL实现OpenGL渲染框架
android·开发语言·图像处理·android studio
wjs202419 分钟前
Perl 发送邮件
开发语言
隔壁小查44 分钟前
【后端开发】Spring MVC-常见使用、Cookie、Session
java·spring·mvc
呦呦鹿鸣Rzh1 小时前
SpringMVC的请求-文件上传
java·前端·html
Java技术小馆1 小时前
SpringBoot 为何启动慢
java·面试·架构
Azir121381 小时前
Stream和CompletableFuture结合起来引发的问题
java·后端
大刘讲IT1 小时前
构建实时、融合的湖仓一体数据分析平台:基于 Delta Lake 与 Apache Iceberg
开发语言·python·sql·mysql·数据挖掘·数据分析·json