Java中的LinkedBlockingDeque add()方法

这个 加(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
喜欢就支持一下吧
点赞11 分享