El método add(E e) de LinkedBlockingDeque inserta el elemento pasado en el parámetro al final de Deque si hay espacio. Si LinkedBlockingDeque tiene una capacidad restringida y no queda espacio para la inserción, devuelve una excepción IllegalStateException . Funciona exactamente de la misma manera que lo hace el método addLast().
Sintaxis:
public void add(E e)
Parámetros: Este método acepta un parámetro obligatorio e que es el elemento a insertar al final del LinkedBlockingDeque.
Devoluciones: Este método no devuelve nada.
Excepción:
- IllegalStateException : si el elemento no se puede agregar en este momento debido a restricciones de capacidad
- NullPointerException : si el elemento especificado es nulo
Los siguientes programas ilustran el método add() de LinkedBlockingDeque:
Programa 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); } }
Producción:
Linked Blocking Deque: [7855642, 35658786, 5278367, 74381793]
Programa 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); } }
Producción:
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)
Programa 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); } }
Producción:
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)
Referencia: https://docs.oracle.com/javase/7/docs/api/java/util/concurrent/LinkedBlockingDeque.html#add(E)