class Factory { private int[] items = new int[1]; // 数据存储容器(为了演示,设置容量最多存储 1 个元素) private int size = 0; // 实际存储大小 /** * 生产方法 */ public synchronized void put() throws InterruptedException { // 循环生产数据 do { System.out.println(size + " " + items.length); while (size == items.length) { // 注意不能是 if 判断 // 存储的容量已经满了,阻塞等待消费者消费之后唤醒 System.out.println(Thread.currentThread().getName() + " 进入阻塞"); this.wait(); System.out.println(Thread.currentThread().getName() + " 被唤醒"); } System.out.println(Thread.currentThread().getName() + " 开始工作"); items[0] = 1; // 为了方便演示,设置固定值 size++; System.out.println(Thread.currentThread().getName() + " 完成工作"); // 当生产队列有数据之后通知唤醒消费者 this.notify();
生产者消费者(notify、wait)
于 2014-04-12 12:30:27 首次发布
本文深入探讨了Java中的生产者消费者问题,讲解了如何利用notify和wait方法实现线程间的通信与同步,阐述了其在多线程编程中的应用与重要性。
摘要由CSDN通过智能技术生成