El método putLast(E e) de LinkedBlockingDeque inserta el elemento especificado en la cola representada por esta deque (en otras palabras, al final/final de esta deque). Si el Deque tiene una capacidad restringida, entonces esperará a que el espacio esté disponible.
Sintaxis:
public void putLast(E e)
Parámetros: este método acepta un parámetro obligatorio e que es el elemento que se insertará al final de LinkedBlockingDeque.
Devoluciones: este método no devuelve nada.
Excepciones: el programa lanza dos excepciones como se muestra a continuación:
- NullPointerException : si el elemento especificado es nulo
- InterruptedException : si se interrumpe mientras espera
Los siguientes programas ilustran el método putLast() de LinkedBlockingDeque:
Programa 1:
// Java Program Demonstrate putLast() // method of LinkedBlockingDeque import java.util.concurrent.LinkedBlockingDeque; import java.util.*; public class GFG { public static void main(String[] args) throws InterruptedException { // create object of LinkedBlockingDeque LinkedBlockingDeque<Integer> LBD = new LinkedBlockingDeque<Integer>(); // Add numbers to end of LinkedBlockingDeque LBD.putLast(7855642); LBD.putLast(35658786); LBD.putLast(5278367); LBD.putLast(74381793); // print Dequeue System.out.println("Linked Blocking Deque: " + LBD); } }
Linked Blocking Deque: [7855642, 35658786, 5278367, 74381793]
Programa 2:
// Java Program Demonstrate putLast() // method of LinkedBlockingDeque // throwing NullPointerException import java.util.concurrent.LinkedBlockingDeque; import java.util.*; public class GFG { public static void main(String[] args) throws InterruptedException { // create object of LinkedBlockingDeque LinkedBlockingDeque<Integer> LBD = new LinkedBlockingDeque<Integer>(); // Add numbers to end of LinkedBlockingDeque LBD.putLast(7855642); LBD.putLast(35658786); LBD.putLast(5278367); // throws an exception LBD.putLast(null); // print Dequeue System.out.println("Linked Blocking Deque: " + LBD); } }
Salida :
Runtime Errors: Exception in thread "main" java.lang.NullPointerException at java.util.concurrent.LinkedBlockingDeque.putLast(LinkedBlockingDeque.java:390) at GFG.main(GFG.java:23)
Programa 3:
// Java Program Demonstrate putLast() // method of LinkedBlockingDeque // when capacity exceeded import java.util.concurrent.LinkedBlockingDeque; import java.util.*; public class GFG { public static void main(String[] args) throws InterruptedException { // create object of LinkedBlockingDeque LinkedBlockingDeque<Integer> LBD = new LinkedBlockingDeque<Integer>(3); // Add numbers to end of LinkedBlockingDeque LBD.putLast(7855642); LBD.putLast(35658786); LBD.putLast(5278367); // throws an exception LBD.putLast(4356789); // print Dequeue System.out.println("Linked Blocking Deque: " + LBD); } }
Salida :
Runtime Errors: Max real time limit exceeded due to either by heavy load on server or by using sleep function
Referencia: https://docs.oracle.com/javase/8/docs/api/java/util/concurrent/LinkedBlockingDeque.html#putLast-E-