当前位置: 首页 > news >正文

线程间通信:wait和notify

线程间通信:wait和notify

1、Object的wait和notify方法

Java中的Object类提供了两个重要的方法,用于线程间的通信和同步:wait()方法和notify()方法

wait()方法的定义

  • 方法签名public final void wait() throws InterruptedException
  • 功能:使当前线程等待,直到其他线程调用此对象的notify()notifyAll()方法。换句话说,当一个线程调用某个对象的wait()方法时,它会进入这个对象的等待池中,并释放该对象的对象锁(监视器)。
  • 使用条件:必须在同步块(synchronized block)或同步方法中调用,因为当前线程必须拥有该对象的监视器。如果试图在非同步环境中调用wait(),会抛出IllegalMonitorStateException异常。

notify()方法的定义

  • 方法签名public final void notify()
  • 功能:唤醒在此对象监视器上等待的单个线程。如果有多个线程都在此对象上等待,则选择一个线程进行唤醒,选择是任意性的。注意,调用notify()方法并不会立即使等待线程从wait()返回,而是需要等到当前线程释放了该对象的监视器之后,被选中的等待线程才有机会获得该监视器并继续执行。
  • 使用条件:也必须在同步块或同步方法中调用,因为当前线程必须拥有该对象的监视器。如果试图在非同步环境中调用notify(),也会抛出IllegalMonitorStateException异常。

2、消费者和生产者代码

商店类

import java.util.ArrayList;
import java.util.List;public class Store {public Store(){}private List<String> apples = new ArrayList<>();private Object o = new Object();public void custom(){synchronized(o){if (apples.size() == 0) {try {o.wait();} catch (InterruptedException e) {e.printStackTrace();}}String apple = apples.get(apples.size()-1);System.out.println("消费者消费了:"+apple);apples.remove(0);o.notify();}}public void product(String apple){synchronized(o){if (apples.size() > 0) {try {o.wait();} catch (InterruptedException e) {e.printStackTrace();}}apples.add(apple);System.out.println("生产者生产了:"+apple);o.notify();}}}

消费者类

public class Customer implements Runnable{private Store store;public Customer(Store store){this.store = store;}@Overridepublic void run() {for (int i = 0; i < 100; i++) {store.custom();                }}}

生产者类

public class Producter implements Runnable{private Store store;public Producter(Store store){this.store = store;}@Overridepublic void run() {for (int i = 0; i < 100; i++) {store.product("苹果"+i);}}}

执行类

import java.util.ArrayList;
import java.util.List;public class CustomerProducter {/*** 1. 生产者:没有产品,就要开始生产,生产完毕通知消费者,有产品等待消费者消费* 2. 消费者:有产品,开始消费,消费完毕通知生产者,没有产品等待生产者生产* 3. 缓冲区* */public static void main(String[] args) {Store store = new Store();Customer customer = new Customer(store);Producter producter = new Producter(store);new Thread(customer).start();new Thread(producter).start();}}

执行结果

生产者生产了:苹果0
消费者消费了:苹果0
生产者生产了:苹果1
消费者消费了:苹果1
...
生产者生产了:苹果98
消费者消费了:苹果98
生产者生产了:苹果99
消费者消费了:苹果99
http://www.lryc.cn/news/487477.html

相关文章:

  • 风险识别和管理的工具
  • qt之QFTP对文件夹(含嵌套文件夹和文件)、文件删除下载功能
  • 为何数据库推荐将IPv4地址存储为32位整数而非字符串?
  • Mybatis框架之责任链模式 (Chain of Responsibility Pattern)
  • C++ Stack和Queue---单向守护与无尽等待:数据结构的诗意表达
  • 深入理解Java包装类与泛型的应用
  • 【机器学习chp4】特征工程
  • LeetCode螺旋矩阵
  • 第十五届蓝桥杯JAVA的B组题目详情解析
  • 在几分钟内将数据从 Oracle 迁移到 ClickHouse
  • ASP.NET MVC宠物商城系统
  • 完整http服务器
  • 【专题】2024AIGC创新应用洞察报告汇总PDF洞察(附原数据表)
  • 形态学图像处理(Morphological Image Processing)
  • 【IDER、PyCharm】免费AI编程工具完整教程:ChatGPT Free - Support Key call AI GPT-o1 Claude3.5
  • C++11的一些实用特性
  • 23种设计模式-观察者(Observer)设计模式
  • 【CUDA】Branch Divergence and Unrolling Loop
  • 深度学习:卷积神经网络的计算复杂度,顺序操作,最大路径长度
  • springboot 配置文件中 multipart.max-file-size 各个版本的写法
  • linux 中mysql查看慢日志
  • 单片机的基本组成与工作原理
  • 智慧隧道和智慧交通
  • List、Set、Map详解和区别
  • 界面控件DevExpress WinForms v24.2新功能预览 - 支持.NET 9
  • Postman之pm.test断言操作
  • 对数几率回归
  • docker 配置同宿主机共同网段的IP 同时通过通网段的另一个电脑实现远程连接docker
  • 4-7-1.C# 数据容器 - LinkedList(LinkedList 的定义、LinkedList 结点的遍历、LinkedList 的常用方法)
  • 「三」体验HarmonyOS端云一体化开发模板——使用DevEco Studio直接创建端云一体化工程