• Java Queue add/offer ,element/peek , remove/poll 区别说明


    在 Java Queue 上 add/offer ,element/peek , remove/poll 中三个方法均为重复方法 , 在选择使用时不免有所疑惑 , 这是简单说明下 :

    1. add() 和 offer() 的区别

    add() 和 offer() 都是向队列中添加一个元素 . 一些队列有大小限制,因此如果想在已满的队列加入一个新队列, 调用 add() 方法就会抛出一个 unchecked 异常, 而调用 offer() 方法返回 flase . 因此就可以在程序中进行有效的判断 .

    2. poll() 和 remove() 的区别

    poll() 和 remove() 方法都是从队列中删除第一个元素. 如果队列元素为空 ,调用 remove() 的行为与 Collection 接口的版本相似会抛出异常 . 但是新的 poll() 方法会在用空集合调用时只会返回 null . 因此新的方法更适合容易出现异常条件的情况.

    3. element() 和 peek() 的区别

    element() 和 peek()用于在队列的头部查询元素. 与 remove() 方法类似 , 在队列为空时 , element () 抛出一个异常 , 而 peek()返回 null .

    下面 Java 中 Queue 的一些常用方法 :

    其中put()take()BlockingQueue专属方法.

    操作方法作用异常情况
    add 添加一个元素 如果队列已满 , 则抛出一个 IIIegalSlabExcepiton 异常
    offer 添加一个元素并返回true 如果队列已满, 则返回 false
    put 添加一个元素 如果队列已满, 则阻塞
    remove 移除并返回队列头部元素 如果队列为空, 则抛出一个 NoSuchElementException异常
    poll 移除并返回队列头部元素 如果队列为空, 则返回null
    take 移除并返回队列头部元素  
    element 返回队列头部元素 如果队列为空 , 则抛出一个NoSuchElementException 异常
    peek 返回队列头部元素 如果队列为空, 则返回 null
  • 相关阅读:
    团体程序设计天梯赛-练习集L1-002. 打印沙漏
    WUOJ-ACM :1003: 零起点学算法78——牛牛
    ZOJ-2965
    天梯赛-L1-018. 大笨钟
    代码哲学 摒弃“够用就行”的心态
    github 源码阅读
    Biopython SeqIO 读取序列文件,读取信息,写入序列
    Biopython 模块处理Seq序列 方法
    coursera 有比较丰富的生物信息等课程 win7 访问设置
    python 正则匹配 csv文件中特殊符号如■高风险 这样的black block
  • 原文地址:https://www.cnblogs.com/quyc/p/14418761.html
Copyright © 2020-2023  润新知