前言
日常开发中,我们最常用的集合主要有两个,一个是ArrayList,一个是LinkedList
如果对ArrayList还有不明白的同学,可以看一下我之前写的一篇文章:Java集合,ArrayList源码深入解析
那么本篇文章,我们主要是基于LinkedList写一个简单的队列。
设计思路:
首先我们想要设计一个方案的时候,要先捋清楚思路,想一下现有的,别人已经实现的方案,然后思考自己如何才能实现。(比如rabbitMq)
队列管理中心:集中管理所有创建的队列
提供方:往消息队列中发送消息
消费方:监听消息队列中的消息,并进行消费(如果监听到队列中新放入了消息,则自动消费处理)
第一步:实现消息队列
我们要明确队列所需要实现的功能,主要是发送消息,接收消息。
package com.dm.black.modules.myQuere;
import java.util.LinkedList;
/**
* 基于LinkedList实现消息队列
* @author wjy
* @date 2021/1/20
*/
public class MQueue extends QueueCenter {
private LinkedList<Object> queue = new LinkedList<>();
/**
* 注意:这里加锁是为了防止并发操作,因为LinkedList本身是线程不安全的
* @method 放入消息
* @param o
* @return
*/
public boolean putMessage(Object o) {
synchronized (queue) {
// 如果队列在等待,则执行唤醒
if (queue.isEmpty()) {
System.out.println("唤醒队列...");
queue.notifyAll();