Java中队列和堆栈

队列(queue),先进先出(First in first out,FIFO)。

堆栈(stack),后进先出(Last in first out,LIFO)。

      Java中有Stack这个类,但是不推荐使用。通常使用Deque来完成队列和堆栈的功能。

      Deque是一个线性表接口,可以两端进行元素的插入和删除。Deque是“Double ended Queue”的缩写,Deque读音[dɛk] 。使用Deque接口提供的方法就可以完成队列“先进先出”和堆栈“后进先出”的功能:

队列

offer(E e) --- 向队列尾加入元素

E poll() --- 获取队列头部元素,并从队列中删去

堆栈

push(E e) --- 向堆栈中压入元素

E pop() --- 获取栈顶元素,并从堆栈中删除

 

Deque是个接口,其实现类有:

  • ArrayDeque,使用“数组”存储数据
  • LinkedList,使用“链表”存储数据
  • ConcurrentLinkedDeque,线程安全的LinkedList

数据检索多的用ArrayDeque;数据需要频繁插入、更新,则用LinkedList;多线程操作使用ConcurrentLinkedDeque。

代码示例:

   1: Deque<String> queue = new LinkedList<String>();
   2: queue.offer("data1");    //队列尾部加入元素
   3: queue.offer("data2");
   4: queue.offer("data3");
   5: System.out.println(queue.poll());    //取得队首元素,并从队列中删去
   6:  
   7: Deque<String> stack = new LinkedList<String>();
   8: stack.push("element1");    //向栈顶压入元素
   9: stack.push("element2");
  10: stack.push("element3");
  11: System.out.println(queue.pop());    //取得栈顶元素,并从栈顶删去

转载于:https://www.cnblogs.com/tadckle/p/3530084.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值