Java中的队列API——Queue

队列具有FIFO(先进先出)的功能,那么如何实现这一功能呢,呵呵呵,Java已经为我们提供了API——Queue,下面通过一个例子来认识一下该API:

import java.util.Queue;
import java.util.LinkedList;

public class TestQueue {

    public static void main(String[] args) {
        Queue<String> queue = new LinkedList<String>();
        queue.offer("Hello");//将指定的元素插入此队列(如果立即可行且不会违反容量限制),插入成功返回 true;否则返回 false。当使用有容量限制的队列时,offer方法通常要优于 add方法——add方法可能无法插入元素,而只是抛出一个IllegalStateException异常。
        queue.offer("World");
        queue.offer("!");
        System.out.println(queue.size());//输出:3
        String str;
        while((str=queue.poll())!=null){//获取并移除此队列的头,如果此队列为空,则返回 null。 remove方法也可以获取并移除此队列的头,但该方法与 poll方法的唯一不同在于:如果此队列为空,那么remove方法将抛出NoSuchElementException异常。
            System.out.println(str);//换行依次输出:Hello、World、!
        }
        System.out.println(queue.size());//输出:0
    }
}

该API还有两个“获取但并不移除此队列头”方法:

1、element()获取队列的头但不移除此队列的头。如果此队列为空,则将抛出NoSuchElementException异常。
        2、peek()获取队列的头但不移除此队列的头。如果此队列为空,则返回 null。

时间: 2025-01-01 07:54:56

Java中的队列API——Queue的相关文章

【Socket编程】Java中网络相关API的应用

Java中网络相关API的应用 一.InetAddress类 InetAddress类用于标识网络上的硬件资源,表示互联网协议(IP)地址. InetAddress类没有构造方法,所以不能直接new出一个对象: InetAddress类可以通过InetAddress类的静态方法获得InetAddress的对象: 1 InetAddress.getLocalHost();//获取本地对象 2 InetAddress.getByName("");//获取指定名称对象 主要方法使用: 1 /

Java中常用的API

Java中常用的API 1.Random 继承体系:java.util.Random:生成伪随机数流 常用方法:public int nextInt(int n) :返回一个伪随机数,范围在  0 (包括)和 指定值  n (不包括)之间的int 值 备注:创建一个 Random 对象之后,每次调用 其nextXxx() 方法,都会生成一个随机数. 1 import java.util.InputMismatchException; 2 import java.util.Random; 3 im

java中使用队列:java.util.Queue (转)

Queue接口与List.Set同一级别,都是继承了Collection接口.LinkedList实现了Queue接 口.Queue接口窄化了对LinkedList的方法的访问权限(即在方法中的参数类型如果是Queue时,就完全只能访问Queue接口所定义的方法 了,而不能直接访问 LinkedList的非Queue的方法),以使得只有恰当的方法才可以使用.BlockingQueue 继承了Queue接口. 队列是一种数据结构.它有两个基本操作:在队列尾部加人一个元素,和从队列头部移除一个元素就

Java中阻塞队列的使用

http://blog.csdn.net/qq_35101189/article/details/56008342 在新增的Concurrent包中,BlockingQueue很好的解决了多线程中,如何高效安全“传输”数据的问题.通过这些高效并且线程安全的队列类,为我们快速搭建高质量的多线程程序带来极大的便利.本文详细介绍了BlockingQueue家庭中的所有成员,包括他们各自的功能以及常见使用场景. 认识BlockingQueue阻塞队列,顾名思义,首先它是一个队列,而一个队列在数据结构中所

Java中的堆栈API——Stack

堆栈(stack)是线性表的一种,只能在该线性表的表尾进行插入.获取或删除的操作.该线性表具有LIFO(后进先出)的特点,那么Java中如何实现这一功能呢,呵呵呵,Java已经为我们提供了API--Stack,Stack类继承Vector类.下面通过一个例子来认识一下该API: import java.util.Stack; public class TestStack { public static void main(String[] args) { Stack<String> stack

java中的队列Queue

一.概述 其位于java.util包下,声明:public interface Queue<E> extends Collection<E> 在处理元素前用于保存元素的 collection.除了基本的 Collection 操作外,队列还提供其他的插入.提取和检查操作.每个方法都存在两种形式:一种抛出异常(操作失败时),另一种返回一个特殊值(null 或 false,具体取决于操作).插入操作的后一种形式是用于专门为有容量限制的 Queue 实现设计的:在大多数实现中,插入操作不

Java中使用LinkedList实现Queue

LinkedList提供了方法支持队列的行为,并且它实现了Queue接口,因此LinkedList可以用作Queue的一种实现. package cn.usst.queue.demo; import java.util.LinkedList; import java.util.Queue; import java.util.Random; /* * Queue的基本使用 */ public class QueueDemo { public static void main(String[] ar

JAVA中常用的API -----(一)

Java API就是JDK中提供给我们使用的类,这些类将底层的代码实现封装了起来,我们不需要关心这些类是如何实现的,只需要学习这些类如何使用即可. 一.Object类是Java语言中的根类,即所有类的父类. 1. equals方法,用于对比两个对象是否相同.它其实比较的是两个对象的内存地址. equals方法内部使用的就是==运算符. package com.oracle.demo01; import com.oracle.demo01.person.Person; public class p

java中的队列

非阻塞队列:ConcurrentLinkedQueue ConcurrentLinkedQueue是一个基于链接节点的无界线程安全队列,它采用先进先出的规则对节点进行排序,当我们添加一个元素的时候,它会添加到队列的尾部,当我们获取一个元素时,它会返回队列头部的元素. 阻塞队列:BlockingQueue 1. ArrayBlockingQueue      基于数组的阻塞队列实现,在ArrayBlockingQueue内部,维护了一个定长数组,以便缓存队列中的数据对象,这是一个常用的阻塞队列,除