IT博客汇
  • 首页
  • 精华
  • 技术
  • 设计
  • 资讯
  • 扯淡
  • 权利声明
  • 登录 注册

    [原]Java中的队列API——Queue

    wangshuxuncom发表于 2015-04-16 08:48:17
    love 0

    队列(queue)是线性表的一种,只允许在该线性表的前端(front,又称为队头)进行获取或删除操作,而在该线性表的后端(rear,又称为队尾)进行插入操作。该线性表具有FIFO(先进先出)的特点,那么Java中如何实现这一功能呢,呵呵呵,Java已经为我们提供了API——Queue,下面通过一个例子来认识一下该API:

    import java.util.Queue;
    import java.util.LinkedList;
    
    public class TestQueue {
    	
        public static void main(String[] args) {
            Queue queue = new LinkedList();
            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。



沪ICP备19023445号-2号
友情链接