5.6(java学习笔记) queue

5.6(java学习笔记) queue

一.queue接口

queue的中文意思是队列,是一种以先进先出方式处理数据的集合。

 

队列还提供额外的插入、提取和检查操作。这些方法都以两种形式存在:一种在操作失败时抛出异常,另一种返回特殊值(根据操作,为空或为假)。

后一种形式的插入操作是专门针对容量受限的队列实现设计的

 

5.6(java学习笔记) queue

有些方法以两种形式存在,只是操作失败时处理的方式不同,一个是抛出异常,一个是返回特殊值(false或null)。

这个根据自己需要进行选择。

 

实现这个接口的类有:

5.6(java学习笔记) queue

 

下面说两个常用方法。

1.boolean offer(E e)

向队列中插入元素,如果操作成功返回true,反之返回false。

 

2.E poll()

检索并移除队列的头部,返回移除的队列头部元素,如果头部为空则返回null。

 

我们来举个例子:

import java.util.ArrayDeque;
import java.util.Queue;

public class Demo01 {
    public static void main(String[] args) {
        Queue<Request> que = new ArrayDeque<Request>();//ArrayDeque是支持容量扩展的。
        for(int i = 0; i < 10; i++){
            final int num = i;
            que.offer(new Request(){//在队列中放入10个元素,此处使用匿名内部类
                @Override
                public void deposit() {
                    // TODO Auto-generated method stub
                    System.out.println("第"+num+"个人存款:" + Math.random()*10000);//生产随机出模拟存款
                }
            });
        }
        dealWith(que);//输出队列。
        System.out.println("--------");
        dealWith(que);
    }
    public static void dealWith(Queue<Request> que){//输出队列的方法
        Request req = null;
        while((req = que.poll()) != null){
            req.deposit();
        }
    }
}

interface Request{//定义的一个接口
    void deposit();
}

运行结果:
第0个人存款:8619.233801715016
第1个人存款:5111.3672776256135
第2个人存款:3833.7846958074883
第3个人存款:534.977625279095
第4个人存款:40.69671570731348
第5个人存款:986.8179704462143
第6个人存款:5995.7651112520325
第7个人存款:8142.90423161368
第8个人存款:5153.935940310687
第9个人存款:4599.385486329686
--------

可以看到,poll是移除队列头部并返回,所以输出完后无法再次输出队列。

 

其实添加元素就是不停在队列尾部添加,移除时不停将头部置为null并将头部后移。

我们来看下源码:

用于存放数据的是一个object类型的数组。

5.6(java学习笔记) queue

初始长度为16,容量不足可自动扩容。

 

offer(E e)

5.6(java学习笔记) queue

5.6(java学习笔记) queue

5.6(java学习笔记) queue

offer()最后调用的是addLast,tail是尾部的索引,我们可以看到将元素添加到尾部后,

尾部索引后移一位。

 

我们接着来看下poll();

5.6(java学习笔记) queue

5.6(java学习笔记) queue

移除元素就将头部元素给result,然后判断下如果头部为空则返回null.

后面将头部置null,然后返回头部元素,头部索引后移一位。

 

我们可以发现在队列中有向头部添加元素的方法,也有像尾部添加元素的方法。

这些结合下,我们能否用队列实现堆栈的功能?

 

堆栈是先进后出,我们也看了上列代码中添加时是在尾部添加,最后获取时是在头部获取才造成了先进先出的现象。

假如我们不断在尾部添加,添加完后再不断从尾部获取这样是不是就是实现了后进先出。

还是上列代码,我们只需要修改一个地方就可以了,将从头部开始移除并返回移除元素,改成从尾部开始移除,并返回尾部元素即可。

 

import java.util.ArrayDeque;
import java.util.Queue;

public class Demo01 {
    public static void main(String[] args) {
        Queue<Request> que = new ArrayDeque<Request>();for(int i = 0; i < 10; i++){
            final int num = i;
            que.offer(new Request(){
                @Override
                public void deposit() {
                    // TODO Auto-generated method stub
                    System.out.println("第"+num+"个人存款:" + Math.random()*10000);
                }
            });
        }
        dealWith(que);
        System.out.println("--------" + o.length);
        dealWith(que);
    }
    public static void dealWith(Queue<Request> que){
        Request req = null;
        while((req = ((ArrayDeque<Request>) que).pollLast()) != null){//将poll中原先调用pollFirst改为pollLast.
            req.deposit();
        }
    }
}

interface Request{
    void deposit();
}

运行结果:
第9个人存款:4418.752779875663 第8个人存款:894.3762449014581 第7个人存款:6559.006752015596 第6个人存款:2725.551000497387 第5个人存款:1180.896859117061 第4个人存款:7267.814454629828 第3个人存款:9021.26681251365 第2个人存款:5066.769610999404 第1个人存款:6173.24968987338 第0个人存款:6288.854161224456 --------
//从后向前移除就是将尾部元素返回,并且将尾部前移一位。

转载于:https://www.cnblogs.com/huang-changfan/p/9800498.html

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/101367.html原文链接:https://javaforall.net

(0)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • 失而复得的爱情「建议收藏」

    失而复得的爱情「建议收藏」 那年夏天,长江边,夕阳还有一点点余辉,欢快的蛐蛐叫个不停。他和她坐在江边的石阶上,凝视波浪起伏的江面,任晚风吹乱本已理不清的思绪。  父母的叮咛始终绕在他的耳畔:“到大学要好好学习,你是我们的骄傲。”他不想因为谈恋爱而影响学习,让父母失望。虽然,她曾为他付出了很多,同时,他也恨自己,为什么当初要接受她?而她也知道他要对她说什么。  江水是浑浊的,心是沉重的。  风起了,江里的浪一浪高过一浪,气温

    2026年1月16日
    3
  • python中for循环加速_如何提高python 中for循环的效率[通俗易懂]

    python中for循环加速_如何提高python 中for循环的效率[通俗易懂]对于某个城市的出租车数据,一天就有33210000条记录,如何将每辆车的数据单独拎出来放到一个专属的文件中呢?思路很简单:就是循环33210000条记录,将每辆车的数据搬运到它该去的文件中。但是对于3000多万条数据,一个一个循环太消耗时间,我花了2个小时才搬运了60万数据,算算3000万我需要花费100个小时,也就需要4-5天。并且还需要保证这五天全天开机,不能出现卡机的事故。因此,需要使用并行…

    2022年8月12日
    11
  • Runnable和Callable区别[通俗易懂]

    RunnableRunnable是一个接口,该接口中只有一个run方法,实现Runnable接口的类需要重写run方法,然后可以把这个类作为Thread类的一个参数,来创建线程,具体的用法有两种:创建一个类,实现Runnable接口,重写run方法classMyThreadimplementsRunnable{@Overridepublicvoidrun(){System.out.println(“MyThread”);}}使

    2022年4月7日
    58
  • c语言定义函数指针和typedef简写

    c语言定义函数指针和typedef简写

    2021年9月17日
    46
  • NLP学习路线总结

    NLP学习路线总结目录1、自然语言处理概述2、自然语言处理入门基础3、自然语言处理的主要技术范畴4、自然语言处理基本点5、特征处理6、模型选择7、NLP常用工具8、NLP语言模型9、快速入门NLP方法10、自然语言处理学习资料1、自然语言处理概述自然语言处理(NaturalLanguageProcessing,NLP)是计算机科学领域与人工智能领域中的一个重要方向…

    2022年9月28日
    5
  • 时钟模块ds1302的使用软件_ds1302时钟程序详解

    时钟模块ds1302的使用软件_ds1302时钟程序详解  刚刚学习了如何使用ds1302这个时钟芯片的使用,现在我把学习的过程分享出来,虽然整体的过程感觉不算难,但是仍然有难解之处至今未明,因为没有去实际验证,所以也不能确定到底是什么原因。  1.首先,查找ds1302手册,可以在21ic这个网站上下载。如果嫌英文版的自己翻译的很难受(这里还是建议大家硬着头皮看英文版的,毕竟是有好处的,你说呢?),可以在网上找中文版的。  2.通过手册…

    2025年7月1日
    3

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号