利用Condition实现生产者和消费者资源共享

本文详细介绍了Java并发编程中Condition机制的特点及其实现方式。Condition提供了一种比Object.wait()/notify()更灵活的线程间协作机制,支持多个Condition实例与同一把锁关联,从而实现更精确的线程唤醒控制。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

 

Condition的特性:

  1.Condition中的await()方法相当于Object的wait()方法,Condition中的signal()方法相当于Object的notify()方法,Condition中的signalAll()相当于Object的notifyAll()方法。不同的是,Object中的这些方法是和同步锁捆绑使用的,而Condition是需要与互斥锁/共享锁捆绑使用的。

  2.Condition它更强大的地方在于:能够更加精细的控制多线程的休眠与唤醒。对于同一个锁,我们可以创建多个Condition,在不同的情况下使用不同的Condition。如果采用Object类中的wait(), notify(), notifyAll(),不可能通过notify()或notifyAll()明确的指定唤醒"线程",而只能通过notifyAll唤醒所有线程(但是notifyAll无法区分唤醒的线程是读线程,还是写线程)。  但是,通过Condition,就能明确的指定唤醒线程。

公共资源:

import java.util.concurrent.locks.Condition;
import java.util.concurrent.locks.Lock;
import java.util.concurrent.locks.ReentrantLock;

/**
 * 公共资源,包含消费和生产两个方法
 */
public class Basket {

    private Lock lock;
    private Condition produced;
    private Condition consumed;
    private int num;
    public Basket(){
        lock = new ReentrantLock();
        produced = lock.newCondition();
        consumed = lock.newCondition();
    }

    public void produce() throws InterruptedException {
        lock.lock();
        System.out.println("Producer get a lock...");
        try {
            while(num==1){
                System.out.println("Producer sleep...");
                produced.await();
            }

            Thread.sleep(1000);
            System.out.println("Producer produce an apple");
            num = 1;
            consumed.signal();
        } finally {
            lock.unlock();
        }
    }


    public void consume() throws InterruptedException {
        lock.lock();
        System.out.println("Consumer get a lock...");
        try {
            while(num == 0){
                System.out.println("Consumer sleep...");
                consumed.await();
            }

            Thread.sleep(500);
            System.out.println("Consumer consume an apple");
            num = 0;
            produced.signal();
        } finally {
            lock.unlock();
        }
    }
}

生产者:

public class Producer implements Runnable {

    private Basket basket;
    public Producer(Basket basket){
        this.basket = basket;
    }

    @Override
    public void run() {
        try {
            basket.produce();
        } catch (InterruptedException e) {
            e.printStackTrace();
        }
    }
}

消费者:

public class Consumer implements Runnable {

    private Basket basket;
    public Consumer(Basket basket){
        this.basket = basket;
    }

    @Override
    public void run() {
        try {
            basket.consume();
        } catch (InterruptedException e) {
            e.printStackTrace();
        }
    }
}


测试代码:

public class BaskerTest {
    private static int corePoolSize = 4;
    private static int maximumPoolSize = 20;
    private static long keepAlive = 100;

    public static void main(String[] args) {
        Basket basket = new Basket();
        ExecutorService service = new ThreadPoolExecutor(corePoolSize, maximumPoolSize, keepAlive, TimeUnit.SECONDS, new LinkedBlockingDeque<Runnable>(20));
        //ExecutorService service = Executors.newCachedThreadPool();
        for(int i=0;i<3;i++){
            service.submit(new Producer(basket));
        }

        for(int i=0; i<3; i++){
            service.submit(new Consumer(basket));
        }

        service.shutdown();
    }
}

 

 

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值