Java从零开始学多线程——7.线程间的通信 wait、notify、notifyAll 等待通知经典模型之生产者消费者 使用管道流进行通信 PipedOutputStream、PipedInputS

本文介绍了Java多线程中线程间的通信,讲解了wait、notify、notifyAll的使用场景及区别,并通过生产者消费者模型进行实战演示。此外,还探讨了使用管道流PipedOutputStream和PipedInputStream实现线程间通信的方法。
摘要由CSDN通过智能技术生成

wait、notify、notifyAll

何时使用
在多线程环境下,有时候一个线程的执行,依赖于另外一个线程的某种状态的改变,这个时候,我们就可以使用wait与notify或者notifyAll

wait跟sleep的区别
wait会释放持有的锁,而sleep不会,sleep只是让线程在指定的时间内,不去抢占cpu的资源 注意点 wait notify必须放在同步代码块中, 且必须拥有当前对象的锁,即不能取得A对象的锁,而调用B对象的wait 哪个对象wait,就得调哪个对象的notify

notify跟notifyAll的区别
nofity随机唤醒一个等待的线程​ notifyAll唤醒所有在该对象上等待的线程

代码实操

1.两个线程,只用while循环+flag来判断是否执行,消耗资源

public class Demo 
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

Java天下第1

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值