What is the difference between the add and offer methods in a Queue in Java?

前端 未结 8 1479
盖世英雄少女心
盖世英雄少女心 2020-12-12 13:29

Take the PriorityQueue for example http://java.sun.com/j2se/1.5.0/docs/api/java/util/PriorityQueue.html#offer(E)

Can anyone give me an example of a Queu

8条回答
  •  攒了一身酷
    2020-12-12 13:48

    I guess the difference is in the contract, that when element can not be added to collection the add method throws an exception and offer doesn't.

    From: http://java.sun.com/j2se/1.5.0/docs/api/java/util/Collection.html#add%28E%29

    If a collection refuses to add a particular element for any reason other than that it already contains the element, it must throw an exception (rather than returning false). This preserves the invariant that a collection always contains the specified element after this call returns.

    From: http://java.sun.com/j2se/1.5.0/docs/api/java/util/Queue.html#offer%28E%29

    Inserts the specified element into this queue, if possible. When using queues that may impose insertion restrictions (for example capacity bounds), method offer is generally preferable to method Collection.add(E), which can fail to insert an element only by throwing an exception.

提交回复
热议问题