欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页  >  IT编程

解析Java中的队列和用LinkedList集合模拟队列的方法

程序员文章站 2024-03-06 12:15:32
api中对队列的说明:   public interface queue extends collection

api中对队列的说明:
 

public interface queue<e>
extends collection<e>

在处理元素前用于保存元素的 collection。除了基本的 collection 操作外,队列还提供其他的插入、提取和检查操作。每个方法都存在两种形式:一种抛出异常(操作失败时),另一种返回一个特殊值(null 或 false,具体取决于操作)。插入操作的后一种形式是用于专门为有容量限制的 queue 实现设计的;在大多数实现中,插入操作不会失败。

解析Java中的队列和用LinkedList集合模拟队列的方法

队列通常(但并非一定)以 fifo(先进先出)的方式排序各个元素。不过优先级队列和 lifo 队列(或堆栈)例外,前者根据提供的比较器或元素的自然顺序对元素进行排序,后者按 lifo(后进先出)的方式对元素进行排序。无论使用哪种排序方式,队列的头 都是调用 remove() 或 poll() 所移除的元素。在 fifo 队列中,所有的新元素都插入队列的末尾。其他种类的队列可能使用不同的元素放置规则。每个 queue 实现必须指定其顺序属性。
如果可能,offer 方法可插入一个元素,否则返回 false。这与 collection.add 方法不同,该方法只能通过抛出未经检查的异常使添加元素失败。offer 方法设计用于正常的失败情况,而不是出现异常的情况,例如在容量固定(有界)的队列中。
remove() 和 poll() 方法可移除和返回队列的头。到底从队列中移除哪个元素是队列排序策略的功能,而该策略在各种实现中是不同的。remove() 和 poll() 方法仅在队列为空时其行为有所不同:remove() 方法抛出一个异常,而 poll() 方法则返回 null。
element() 和 peek() 返回,但不移除,队列的头。
queue 接口并未定义阻塞队列的方法,而这在并发编程中是很常见的。blockingqueue 接口定义了那些等待元素出现或等待队列中有可用空间的方法,这些方法扩展了此接口。
queue 实现通常不允许插入 null 元素,尽管某些实现(如 linkedlist)并不禁止插入 null。即使在允许 null 的实现中,也不应该将 null 插入到 queue 中,因为 null 也用作 poll 方法的一个特殊返回值,表明队列不包含元素。
queue 实现通常未定义 equals 和 hashcode 方法的基于元素的版本,而是从 object 类继承了基于身份的版本,因为对于具有相同元素但有不同排序属性的队列而言,基于元素的相等性并非总是定义良好的。

在java里使用队列可以用linkedlist集合进行模拟


方法
使用linkedlist集合,并使用其中的addlast、removefirst、isempty等api集体模拟队列操作

入队列

  void addlast(e e); // 将元素插入此列表的结尾 

出队列

  e removefirst(); // 移除并返回列表的第一个元素 

判空

  boolean isempty(); // 判断队列是否为空  

示例代码

    

package corejavaone; 
   
  import java.util.linkedlist; 
  import java.util.nosuchelementexception; 
   
  public class simulatequeue { 
    private linkedlist<integer> queue = new linkedlist<integer>(); 
   
    public boolean isempty() { 
      return this.queue.isempty(); 
    } 
   
    public void enqueue(int data) { 
      this.queue.addlast(data); 
    } 
   
    public int dequeue() throws nosuchelementexception { 
      return this.queue.removefirst(); 
    } 
   
    public static void main(string[] args) { 
      simulatequeue q = new simulatequeue(); 
   
      q.enqueue(1); 
      q.enqueue(2); 
      q.enqueue(3); 
   
      while (! q.isempty()) { 
        int data = q.dequeue(); 
        system.out.println(data); 
      } 
    } 
  }