生产者和消费者

第一:wait和notify方法不是线程对象的方法, 是java中任何一个java对象都有的方法,因为这两个方式是Object类自带的方法。
wait方法和notify方法不是通过线程对象调用的。

 ## wait()方法的作用?

Object o=new Object();
o.wait();
表示:
	让正在o对象上活动的线程进入等待状态,无期限等待,

## notify()方法作用?
Object  o=new Object();
o.notify();
表示:
	唤醒正在o对象上等待的 线程
还有一个notifyAll()方法:
	这个方法是唤醒o对象上处于等待的所有线程

生产者和消费者理解图
理解图代码实现

package com.aaa.production;

import java.lang.reflect.Array;
import java.util.ArrayList;
import java.util.List;
import java.util.Properties;

/*
*
* 实现生产和消费者
*   一个仓库当作共享对象
*   生产者和消费者必须是线程安全的,生产出的东西需要和消费的东西的个数一致
*   有一个生产者和一个消费者
*   生产者和消费者共享一个对象
*        使用List集合当作仓库
*           仓库的数量为1
*           当仓库的数量为1时仓库就满了
*           当仓库的数量为0时仓库为空
* */
@SuppressWarnings("all")
public class Test01 {
    public static void main(String[] args) {

        //创建list集合
        List list=new ArrayList();
        //创建线程对象  两个线程共享一个list集合
        Thread thread=new Thread(new Product(list));
        Thread thread1=new Thread(new Consumption(list));
        //为线程对象设置名称
        thread.setName("生产者线程");
        thread1.setName("消费者线程");
        //启动线程
        thread.start();
        thread1.start();;

    }
}

/*
* 生产者  一直生产
* */
@SuppressWarnings("all")
class  Product implements  Runnable{

    List list;

    public Product (List list){
        this.list=list;
    }

    @Override
    public void run() {

            while (true) {
                synchronized (list) {
                //判断仓库的数量是否为空
                // 如果仓库的数量不为空则代表仓库满了
                // 我们就需要等待被消费
                if (list.size() > 0) {
                    try {
                        list.wait();
                    } catch (InterruptedException e) {
                        e.printStackTrace();
                    }
                }
                //如果仓库没有满,那么就进行给仓库增加
                Object object = new Object();
                list.add(object);
                    System.out.println(Thread.currentThread().getName()+object);
                //增加完之后就需要唤醒等待的线程

                list.notifyAll();
            }
        }
    }
}


/*
* 消费者  一直消费
* */
@SuppressWarnings("all")
class Consumption implements  Runnable{

    List list;

    public Consumption (List list){
        this.list=list;
    }
    @Override
    public void run() {

            while (true) {
                synchronized (list) {
                if (list.size() == 0) {
                    //仓库中已经空了
                    //消费者的线程等待,释放list集合的锁
                    try {
                        list.wait();
                    } catch (InterruptedException e) {
                        e.printStackTrace();
                    }
                }
                    Object remove = list.remove(0);
                    System.out.println(Thread.currentThread().getName()+remove);
                    list.notifyAll();
            }
        }
    }
}

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
在Java中,"生产者-消费者"(Producer-Consumer)模式是一种经典的设计模式,用于解决多线程环境中的同步问题。它定义了两个角色,即生产者(Producer)和消费者(Consumer),它们分别负责创建数据(产品)和消费数据。 **1. 生产者(Producer):** 生产者通常在自己的线程中不断产生新的对象,并将这些对象添加到一个共享的队列(如`BlockingQueue`、`ArrayBlockingQueue`等)中。生产者需要处理可能的数据溢出(队列已满)和资源竞争(队列为空)。 **2. 消费者(Consumer):** 消费者从队列中取出数据并进行处理,消耗掉生产者产生的对象。同样,消费者需要处理可能的数据饥饿(队列空)和资源竞争(队列满)。 **3. 同步机制:** 为了确保生产者消费者之间的同步,Java提供了`synchronized`关键字或`Semaphore`、`CountDownLatch`、`CyclicBarrier`等并发工具。使用这些工具可以控制访问队列的权限,避免数据不一致或死锁。 **4. 示例代码:** 下面是一个简单的`BlockingQueue`实现的生产者消费者示例: ```java import java.util.concurrent.*; public class ProducerConsumer { private final BlockingQueue<String> queue = new LinkedBlockingQueue<>(10); private final Thread producer; private final Thread consumer; public ProducerConsumer() { producer = new Thread(() -> produceData()); consumer = new Thread(() -> consumeData()); producer.start(); consumer.start(); } private void produceData() { while (true) { synchronized (queue) { if (queue.isEmpty()) { try { queue.wait(); // 队列空时等待 } catch (InterruptedException e) { e.printStackTrace(); } } String data = generateData(); // 生产数据 queue.offer(data); // 添加到队列 System.out.println("Produced: " + data); queue.notify(); // 唤醒消费者 } } } private void consumeData() { while (true) { synchronized (queue) { if (queue.isEmpty()) { try { queue.wait(); // 队列空时等待 } catch (InterruptedException e) { e.printStackTrace(); } } String data = queue.take(); // 从队列获取数据 System.out.println("Consumed: " + data); } } } private String generateData() { // 实现数据生成逻辑 return "Data " + UUID.randomUUID().toString(); } public static void main(String[] args) { new ProducerConsumer(); } } ```
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值