这个 加(E) 方法 LinkedBlockingDeque 将参数中传递的元素插入到Deque的末尾,以确定是否有空间。如果LinkedBlockingDeque的容量受限,并且没有空间可供插入,则返回 非法国家例外 。它的工作方式与addLast()方法完全相同。
null
语法:
public void add(E e)
参数: 此方法接受一个强制参数 E 这是要插入到LinkedBlockingDeque末尾的元素。
返回: 此方法不返回任何内容。
例外情况:
- 非法国家例外 :如果由于容量限制,此时无法添加元素
- 空指针异常 :如果指定的元素为空
下面的程序演示了LinkedBlockingDeque的add()方法:
项目1:
// Java Program Demonstrate add() // method of LinkedBlockingDeque import java.util.concurrent.LinkedBlockingDeque; import java.util.*; public class GFG { public static void main(String[] args) throws IllegalStateException { // create object of LinkedBlockingDeque LinkedBlockingDeque<Integer> LBD = new LinkedBlockingDeque<Integer>(); // Add numbers to end of LinkedBlockingDeque LBD.add( 7855642 ); LBD.add( 35658786 ); LBD.add( 5278367 ); LBD.add( 74381793 ); // before removing print queue System.out.println( "Linked Blocking Deque: " + LBD); } } |
输出:
Linked Blocking Deque: [7855642, 35658786, 5278367, 74381793]
项目2:
// Java Program Demonstrate add() // method of LinkedBlockingDeque // when it is Full import java.util.concurrent.LinkedBlockingDeque; import java.util.*; public class GFG { public static void main(String[] args) throws IllegalStateException { // create object of LinkedBlockingDeque // size of list LinkedBlockingDeque<Integer> LBD = new LinkedBlockingDeque<Integer>( 3 ); // Add numbers to end of LinkedBlockingDeque LBD.add( 7855642 ); LBD.add( 35658786 ); LBD.add( 5278367 ); // it is full LBD.add( 74381793 ); // before removing print queue System.out.println( "Linked Blocking Deque: " + LBD); } } |
输出:
Exception in thread "main" java.lang.IllegalStateException: Deque full at java.util.concurrent.LinkedBlockingDeque.addLast(LinkedBlockingDeque.java:335) at java.util.concurrent.LinkedBlockingDeque.add(LinkedBlockingDeque.java:633) at GFG.main(GFG.java:23)
方案3:
// Java Program Demonstrate add() // method of LinkedBlockingDeque // when null is inserted import java.util.concurrent.LinkedBlockingDeque; import java.util.*; public class GFG { public static void main(String[] args) throws IllegalStateException { // create object of LinkedBlockingDeque LinkedBlockingDeque<Integer> LBD = new LinkedBlockingDeque<Integer>(); // Add numbers to end of LinkedBlockingDeque LBD.add( 7855642 ); LBD.add( 35658786 ); LBD.add( 5278367 ); // NULL LBD.add( null ); // before removing print queue System.out.println( "Linked Blocking Deque: " + LBD); } } |
输出:
Exception in thread "main" java.lang.NullPointerException at java.util.concurrent.LinkedBlockingDeque.offerLast(LinkedBlockingDeque.java:357) at java.util.concurrent.LinkedBlockingDeque.addLast(LinkedBlockingDeque.java:334) at java.util.concurrent.LinkedBlockingDeque.add(LinkedBlockingDeque.java:633) at GFG.main(GFG.java:23)
参考: https://docs.oracle.com/javase/7/docs/api/java/util/concurrent/LinkedBlockingDeque.html#add(E)
© 版权声明
文章版权归作者所有,未经允许请勿转载。
THE END