Java Queue

对于Queue来说,就是一个FIFO(先进先出)的队列,添加元素只能在队尾,移除只能在队首。

对于这一组方法,成功返回true,在操作失败时抛出异常,这是与下面一组方法的主要区别。

add(E e):添加一个元素到队尾

remove():获取队首的元素,并从队列中移除

element():获取队首的元素,但不从队列中移除

 

这一组,成功返回true,失败时返回一个特殊值(取决于操作,为NULL或false),offer(E e)操作是专为容量受限的队列实现而设计的;在大多数实现中,插入操作不会失败。

offer(E e):添加一个元素到队尾

poll():获取队首的元素,并从队列中移除

peek():获取队首的元素,但不从队列中移除
 

import java.util.ArrayDeque;
import java.util.Queue;
  
/**
 * 使用队列模拟银行存款业务
 * @author Administrator
 *
 */
public class Demo01 {
  
       /**
        * @param args
        */
       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() {
                                   System.out.println("第"+num+"个人,办理存款业务,存款额度为:"+(Math.random()*10000));
                            }
                            
                     });
              }
              
              dealWith(que);           
       }
       //处理业务
       public static void dealWith(Queue<Request> que){
              Request req =null;
              while(null!=(req=que.poll())){
                     req.deposit();
              }
       }
  
}
interface Request{
       //存款
       void deposit();
}

 

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值