转载自:http://uule.iteye.com/blog/2095650?utm_source=tuicool

注意:这都只是接口而已

1、Queue

API

在java5中新增加了java.util.Queue接口,用以支持队列的常见操作。该接口扩展了java.util.Collection接口。

  1. public interface Queue<E>
  2. extends Collection<E>

除了基本的 Collection 操作外,队列还提供其他的插入、提取和检查操作。

每个方法都存在两种形式:一种抛出异常(操作失败时),另一种返回一个特殊值(null 或 false,具体取决于操作)

队列通常(但并非一定)以 FIFO(先进先出)的方式排序各个元素。不过优先级队列和 LIFO 队列(或堆栈)例外,前者根据提供的比较器或元素的自然顺序对元素进行排序,后者按 LIFO(后进先出)的方式对元素进行排序。

在 FIFO 队列中,所有的新元素都插入队列的末尾,移除元素从队列头部移除。

Queue使用时要尽量避免Collection的add()和remove()方法而是要使用offer()来加入元素,使用poll()来获取并移出元素。它们的优点是通过返回值可以判断成功与否,add()和remove()方法在失败的时候会抛出异常。 如果要使用前端而不移出该元素,使用element()或者peek()方法。

offer 方法可插入一个元素,否则返回 false。这与 Collection.add 方法不同,该方法只能通过抛出未经检查的异常使添加元素失败。

remove() 和 poll() 方法可移除和返回队列的头。到底从队列中移除哪个元素是队列排序策略的功能,而该策略在各种实现中是不同的。remove() 和 poll() 方法仅在队列为空时其行为有所不同:remove() 方法抛出一个异常,而 poll() 方法则返回 null。

element() 和 peek() 返回,但不移除,队列的头。

Queue 实现通常不允许插入 null 元素,尽管某些实现(如 LinkedList)并不禁止插入 null。即使在允许 null 的实现中,也不应该将 null 插入到 Queue 中,因为 null 也用作 poll 方法的一个特殊返回值,表明队列不包含元素。

值得注意的是LinkedList类实现了Queue接口,因此我们可以把LinkedList当成Queue来用。

  1. import java.util.Queue;
  2. import java.util.LinkedList;
  3. public class TestQueue {
  4. public static void main(String[] args) {
  5. Queue<String> queue = new LinkedList<String>();
  6. queue.offer("Hello");
  7. queue.offer("World!");
  8. queue.offer("你好!");
  9. System.out.println(queue.size());
  10. String str;
  11. while((str=queue.poll())!=null){
  12. System.out.print(str);
  13. }
  14. System.out.println();
  15. System.out.println(queue.size());
  16. }
  17. }

2、Deque

API

  1. public interface Deque<E>
  2. extends Queue<E>

一个线性 collection,支持在两端插入和移除元素。

名称 deque 是“double ended queue(双端队列)”的缩写,通常读为“deck”。

大多数 Deque 实现对于它们能够包含的元素数没有固定限制,但此接口既支持有容量限制的双端队列,也支持没有固定大小限制的双端队列。

此接口定义在双端队列两端访问元素的方法。提供插入、移除和检查元素的方法。因为此接口继承了队列接口Queue,所以其每种方法也存在两种形式:一种形式在操作失败时抛出异常,另一种形式返回一个特殊值(null 或 false,具体取决于操作)。

a、在将双端队列用作队列时,将得到 FIFO(先进先出)行为。将元素添加到双端队列的末尾,从双端队列的开头移除元素。从 Queue 接口继承的方法完全等效于 Deque 方法,如下表所示:

b、用作 LIFO(后进先出)堆栈。应优先使用此接口而不是遗留 Stack 类。在将双端队列用作堆栈时,元素被推入双端队列的开头并从双端队列开头弹出。堆栈方法完全等效于 Deque 方法,如下表所示:

最新文章

  1. day 2 Linux基础
  2. libevent源码分析:eventop
  3. IntelliLock
  4. Liunx-https-java.lang.NoClassDefFoundError: javax/crypto/SunJCE_b
  5. Objective-C中的@property
  6. Objective-C 协议(protocol)
  7. android判断当前应用程序处于前台还是后台
  8. C#和C++中的float类型
  9. freemark标签中输出boolean值
  10. 支持不同Android设备,包括:不同尺寸屏幕、不同屏幕密度、不同系统设置
  11. 华为交换机批量加入 Vlan 方法
  12. Python数据结构之单链表
  13. eMMC基础技术1:MMC简介
  14. Android Json 解析
  15. First Missing Positive leetcode java
  16. MySQL Replication主从复制环境下修改主库IP
  17. Js 手风琴效果
  18. leetcode个人题解——#56 Merge Intervals
  19. Restful and 前后端分离---AutoTest newman--postman
  20. HDU 3639 Hawk-and-Chicken(强连通缩点+反向建图)

热门文章

  1. mysql 数据操作 多表查询 多表连接查询 内连接
  2. 【Lua】面向对象编程(一)
  3. soapUI-DataSource
  4. django2.0关于path匹配路径页面刷新不出来的问题
  5. python开发之路目录
  6. Linux下安装系统清理软件 BleachBit 1.4
  7. C# static的用法详解
  8. javascript原生事件总结
  9. Fms3中client端与server端交互方式汇总
  10. 20144303石宇森《网络对抗》逆向及Bof基础