Java中的队列是一种线性数据结构,具有多种功能。队列有两个端点,它遵循先进先出(FIFO)原则插入和删除其元素。在本教程中,我们将了解 Java 中队列的两个重要函数,它们是 add() 和 Offer()。
什么是队列?
java中的队列是一个扩展了util和collection包的接口。元素在后端插入并从前端移除。 java中的队列可以使用链表、DeQueue、优先级队列等类来实现。优先级队列是普通队列的扩展形式,每个元素都有一个优先级。
队列的add()方法
该方法用于向队列中插入元素。它将定义的元素(作为参数传递的元素)添加到队列的末尾,并且仅当定义的元素成功添加到末尾时才返回true。如果元素没有添加到队列末尾,add() 方法会抛出异常。
使用此方法,我们可以将整数和字符串值添加到队列中。
例如:add(3) 这将在队列末尾插入 3。
add() 方法总是采用一些参数值。您不能向其传递 null 值,因为 Queue 不接受 Null 值,在这种情况下,它将引发异常。
add()方法中的异常类型
-
IllegalStateException - 当队列达到其最大容量时,会出现此 java 异常。
-
NullPointerException - 当尝试通过 add() 方法输入 null 值时,因为队列不接受 null 值。
示例
下面的程序展示了如何在Java中实现Queue中的add()方法。
import java.util.*; // importing util package with all its features
public class Main {
public static void main(String[] args) {
Queue q = new LinkedList(); // queue declaration
q.add(5); //adding elements to the queue
q.add(6);
q.add(4);
q.add(1);
q.add(8);
System.out.println("Queue is: " + q);
}
}
登录后复制
输出
Queue is: [5, 6, 4, 1, 8]
登录后复制
队列中的offer()方法
该方法用于向队列中插入元素,元素可以是整数或字符串数据类型。它根据队列的容量插入指定的元素。如果特定元素无法插入队列,它不会抛出任何异常。
在 Java 中成功将元素插入到队列后端时,它返回 True。如果队列超出其容量,offer() 方法将返回 false。
例如
offer(3) : this will insert 3 into the queue
offer(“Java”) : this will insert Java into the queue
登录后复制
示例
下面的程序展示了如何在java中实现offer()。
import java.util.*; // importing util package with all its features
public class Main {
public static void main(String[] args) {
Queue q = new LinkedList(); // queue declaration
q.offer("Java"); //inserting elements to the queue
q.offer("is");
q.offer("Good");
System.out.println("Queue is " + q);
}
}
登录后复制
输出
Queue is [Java, is, Good]
登录后复制
add() 和 Offer() 方法之间的区别
S.No |
add() 函数 |
offer() 方法 |
---|---|---|
1 |
当您尝试在已满队列中插入元素时,add() 函数会引发 IllegalState 异常。 |
当队列已满或达到最大大小时,它不会抛出任何异常,但返回 false。 |
2 |
成功插入队列元素后,add() 方法返回 true。它不会返回 False |
offer() 方法在成功插入元素时返回 True,在插入 Queue 元素失败时返回 False。 |
3 |
属于Collection框架。 |
这是一个队列方法。 |
结论
Queue 中的 add() 和 Offer() 方法之间的唯一区别是:如果 add() 超出了队列的限制,则会抛出异常。虽然 Offer() 方法不会抛出任何异常,但它在成功插入元素时返回 true,而在由于队列达到最高容量而导致元素无法插入队列时返回 False。
以上就是在Java中,add()方法和offer()方法在队列中有什么区别?的详细内容,更多请关注每日运维网(www.mryunwei.com)其它相关文章!