天天看点

生产者、消费者阻塞队列-传统版生产者、消费者模型

生产者、消费者模型

生产者负责生产数据,消费者负责消费数据,中间件MQ就是这种模型设计。下面简单实现一个生产者和消费者的模型,实现生产一个数据,消费一个数据。

代码

/**
 *
 * 生产者 消费者阻塞队列 传统版
 *
 * 一个线程对变量+1,一个线程对变量-1
 *
 */
public class PC<T> {

    private volatile int i = 0;

    private Lock lock = new ReentrantLock();
    private Condition condition = lock.newCondition();


   /**
     * 生产者,每次生产一个数据,然后等待消费者消费数据
     */
    public void produce() {
        lock.lock();

        try {
            // 防止线程一直再生成,消费者没有消费
            while (i != 0) {
                condition.await();
            }
            i++;
            System.out.println(Thread.currentThread().getName() + "\t" + i);
            condition.signalAll();
        } catch (InterruptedException e) {
        } finally {
            lock.unlock();
        }

    }

    /**
     * 消费者,每次消费一个数据,然后等待生产者生产数据
     */
    public void consume() {
        lock.lock();

        try {
            // 防止线程一直再消费,生产者没有生产消息
            while (i == 0) {
                condition.await();
            }
            i--;
            System.out.println(Thread.currentThread().getName() + "\t" + i);

            condition.signalAll();
        } catch (InterruptedException e) {
            e.printStackTrace();
        } finally {
            lock.unlock();
        }
    }

}

           

测试

public static void main(String[] args) {
        PC<Integer> pc = new PC<>();
		
        new Thread(() -> {
            for (int i = 0; i < 10; i++) {
            	// 生产
                pc.produce();
            }
        }, "AA").start();

        new Thread(() -> {
            for (int i = 0; i < 10; i++) {
            	// 消费
                pc.consume();
            }
        }, "BB").start();
    }
           

通过测试,可以看到

AA

线程生产一个数据(将i增加到1),然后

BB

线程消费一个数据(将i减去1),这样就是一个通过锁实现的生产者消费者模型(传统版),在高并发的环境下性能不太高