美文网首页
Queue接口分析:add和offer区别,remove和pol

Queue接口分析:add和offer区别,remove和pol

作者: 拿拿guardian | 来源:发表于2020-03-17 18:07 被阅读0次

    原文 https://www.cnblogs.com/hetaoyuan/p/11392167.html

    public interface Queue<E> extends Collection<E> {
      
         /*
        *  add方法,在不违背队列的容量限制的情况,往队列中添加一个元素, 如果添加成功则返回true,  如果因为容量
        * 限制添加失败了,则抛出IllegalStateException异常    
        * 
        *  在有容量限制的队列中,最好使用offer方法
        *  另外,add方法相对与offer方法而言,有一个专门抛出的异常IllegalStateException,代表由于容量限制,
        * 导致不能添加元素的异常,接口中可能看不出,等看具体实现就明白了
        */
        boolean add(E e);
    
       /*
        *
        *  offer方法在不违背容量限制的情况,往队列中添加一个元素,如果添加元素成功,返回true,
        *  如果因为空间限制,无法添加元素则,返回false;
        *  
        *  在有容量限制的队列中,这个offer方法优于add方法,结合上文中add的注释,可知,
        *  在容量限制的队列中, add方法通过抛异常的方式表示容量已满,offer方法通过返回
        *  false的方式表示容量已满,抛异常处理更加耗时,offer直接返回false的方式更好
        * 
        */**
        boolean offer(E e);
    
       /*
        *  删除队列头的元素,这个方法和poll方法的不同之处在于,这个方法在队列为
        * 空的时候选择抛异常
        * 
        */
        E remove();
    
       /*
        *  poll方法也是删除队列头的远,如果队列为空的化,返回null
        * 
        */
        E poll();
    
       /*
        *  返回队列头元素,这个方法和peek方法的区别在于,入股队列为空,将抛异常
        * 
        */
        E element();
    
       /*
        *  返回队列头元素,如果队列为空,将返回空
        * 
        */
        E peek();
    }
    

    相关文章

      网友评论

          本文标题:Queue接口分析:add和offer区别,remove和pol

          本文链接:https://www.haomeiwen.com/subject/lvcxyhtx.html