/*用链表实现的队列--使用的是双端链表
*注意:空指针错误肯定是引用没有指向对象
* */
public class MyLinkedQueue {
private MyFirstAndLastLinkedList list;
private int items; public MyLinkedQueue() {
list = new MyFirstAndLastLinkedList();
items = 0;
} public boolean isEmpty(){
return list.isEmpty();
} public void insert(int key){
list.insertLast(key);
items++;
} public Link remove(){
items--;
return list.deleteFirst();
} public void displayQueue(){
System.out.println("queue--front-- to--rear");
list.displayLinkedList();
} public int size(){
return items;
} public static void main(String[] args) {
MyLinkedQueue queue = new MyLinkedQueue();
for(int i = 0; i < 10; i++){
queue.insert(i);//尾巴插入
}
queue.displayQueue();
queue.remove();//移除头
queue.displayQueue();
}
}
相关文章
- 数据结构Java实现——④数组——>稀疏矩阵十字链表存储法
- RabbitMQ 优点和缺点- 消息可靠性:RabbitMQ 提供了持久化功能和消息确认机制,确保消息在各种情况下都能可靠地存储和处理。 灵活的路由:通过多种交换机类型和绑定规则,RabbitMQ 能够灵活地路由消息到指定的队列。 支持多种消息协议:实现了 AMQP 等(MQTT、STOMP)标准化、开放的消息队列协议,使其能够与多种语言编写的应用程序进行通信。 插件化扩展:RabbitMQ 提供了丰富的插件系统,可以通过插件扩展功能,如死信队列、压缩、追踪等。 高可用性:支持集群模式和镜像队列,确保服务的可用性 易用性和可管理性:提供了丰富的 API 和管理工具,以及多种客户端库和框架支持,易于集成和使用。 多语言支持:RabbitMQ 支持多种编程语言的客户端,包括 Java、Python、Ruby、C#、Node.js 等,方便开发人员集成到各种应用中。 高性能:在处理大量并发消息时表现出色。 广泛的社区支持:拥有庞大的开发者社区和丰富的文档资源。 劣势: 性能和吞吐量较低:相比于 Apache Kafka 等面向大数据流处理的消息队列系统,RabbitMQ 的吞吐量较低,不适合处理海量的实时数据流。RabbitMQ 的设计更注重消息的可靠性和灵活性,而非极高的吞吐性能。
- 队列(存储结构双端链表)--Java实现
- Java中链表、堆栈、队列、二叉树、散列表等数据结构的实现
- JAVA实现最简单的双向链表、队列与栈(内部使用链表形式存储)
- Java单链表(双端链表)简单实现
- Java数据结构之链表、栈、队列、树的实现方法示例
- (4) 数据结构与算法 ---- 线性表 及Java实现 顺序表、链表、栈、队列
- Java单链表、双端链表、有序链表实现原理
- 双端链表实现队列