栏目分类:
子分类:
返回
名师互学网用户登录
快速导航关闭
当前搜索
当前分类
子分类
实用工具
热门搜索
名师互学网 > IT > 面试经验 > 面试问答

Java中的FIFO类

面试问答 更新时间: 发布时间: IT归档 最新发布 模块sitemap 名妆网 法律咨询 聚返吧 英语巴士网 伯小乐 网商动力

Java中的FIFO类

您正在寻找实现Queue接口的任何类,排除

PriorityQueue
PriorityBlockingQueue
不使用FIFO算法。

可能使用(最前面添加一个)和(从前面删除一个然后返回)的linkedList是最容易使用的一个。

add``removeFirst

例如,这是一个使用linkedList排队并检索PI数字的程序:

import java.util.linkedList;class Test {    public static void main(String args[]) {        char arr[] = {3,1,4,1,5,9,2,6,5,3,5,8,9};        linkedList<Integer> fifo = new linkedList<Integer>();        for (int i = 0; i < arr.length; i++) fifo.add (new Integer (arr[i]));        System.out.print (fifo.removeFirst() + ".");        while (! fifo.isEmpty()) System.out.print (fifo.removeFirst());        System.out.println();    }}

另外,如果您 知道 只想将其视为队列(没有链表的其他功能),则可以只使用

Queue
接口本身:

import java.util.linkedList;import java.util.Queue;class Test {    public static void main(String args[]) {        char arr[] = {3,1,4,1,5,9,2,6,5,3,5,8,9};        Queue<Integer> fifo = new linkedList<Integer>();        for (int i = 0; i < arr.length; i++) fifo.add (new Integer (arr[i]));        System.out.print (fifo.remove() + ".");        while (! fifo.isEmpty()) System.out.print (fifo.remove());        System.out.println();    }}

这样的优点是允许您用提供

Queue
接口的任何类替换基础的具体类,而不必过多地更改代码。

基本更改是将的类型更改为

fifo
Queue
并使用
remove()
代替
removeFirst()
,后者对于
Queue
接口不可用。

调用

isEmpty()
仍然可以,因为它属于
Collection
Queue
派生接口。



转载请注明:文章转载自 www.mshxw.com
本文地址:https://www.mshxw.com/it/437772.html
我们一直用心在做
关于我们 文章归档 网站地图 联系我们

版权所有 (c)2021-2022 MSHXW.COM

ICP备案号:晋ICP备2021003244-6号