The putLast(E e) method of BlockingDeque inserts the specified element into the queue represented by this deque (in other words, at the tail/end of this deque). If the Deque is capacity restricted, then it will wait for the space to become available.
Syntax:
public void putLast(E e)
Parameters: This method accepts a mandatory parameter e which is the element to be inserted at the end of the BlockingDeque.
Returns: This method does not return anything.
Exceptions: The program throws two exceptions as shown below:
- NullPointerException – if the specified element is null
- InterruptedException – if interrupted while waiting
Note: The putLast() method of BlockingDeque has been inherited from the LinkedBlockingDeque class in Java.
Below programs illustrate putLast() method of BlockingDeque:
Program 1:
// Java Program Demonstrate putLast() // method of BlockingDeque import java.util.concurrent.LinkedBlockingDeque;
import java.util.concurrent.BlockingDeque;
import java.util.*;
public class GFG {
public static void main(String[] args)
throws InterruptedException
{
// create object of BlockingDeque
BlockingDeque<Integer> BD
= new LinkedBlockingDeque<Integer>();
// Add numbers to end of BlockingDeque
BD.putLast( 7855642 );
BD.putLast( 35658786 );
BD.putLast( 5278367 );
BD.putLast( 74381793 );
// print Dequeue
System.out.println( "Blocking Deque: " + BD);
}
} |
Blocking Deque: [7855642, 35658786, 5278367, 74381793]
Program 2:
// Java Program Demonstrate putLast() // method of BlockingDeque // throwing NullPointerException import java.util.concurrent.LinkedBlockingDeque;
import java.util.concurrent.BlockingDeque;
import java.util.*;
public class GFG {
public static void main(String[] args)
throws InterruptedException
{
// create object of BlockingDeque
BlockingDeque<Integer> BD
= new LinkedBlockingDeque<Integer>();
// Add numbers to end of BlockingDeque
BD.putLast( 7855642 );
BD.putLast( 35658786 );
BD.putLast( 5278367 );
// throws an exception
BD.putLast( null );
// print Dequeue
System.out.println( "Blocking Deque: " + BD);
}
} |
Output:
Exception in thread "main" java.lang.NullPointerException at java.util.concurrent.LinkedBlockingDeque.putLast(LinkedBlockingDeque.java:390) at GFG.main(GFG.java:24)
Program 3:
// Java Program Demonstrate putLast() // method of BlockingDeque // when capacity exceeded import java.util.concurrent.LinkedBlockingDeque;
import java.util.concurrent.BlockingDeque;
import java.util.*;
public class GFG {
public static void main(String[] args)
throws InterruptedException
{
// create object of BlockingDeque
BlockingDeque<Integer> BD
= new LinkedBlockingDeque<Integer>( 3 );
// Add numbers to end of BlockingDeque
BD.putLast( 7855642 );
BD.putLast( 35658786 );
BD.putLast( 5278367 );
// throws an exception
BD.putLast( 4356789 );
// print Dequeue
System.out.println( "Blocking Deque: " + BD);
}
} |
Output:
Max real time limit exceeded due to either by heavy load on server or by using sleep function
Reference: https://docs.oracle.com/javase/7/docs/api/java/util/concurrent/BlockingDeque.html#putLast(E)