LinkedBlockingDeque take() method in Java
Last Updated :
26 Nov, 2018
The take() method of LinkedBlockingDeque returns and removes the head of the Deque container from it. The method throws an InterruptedException if it is interrupted while waiting.
Syntax:
public E take()
Returns: This method returns the head of the Deque container.
Exception: The function throws a InterruptedException if it is interrupted while waiting.
Below programs illustrate take() method of LinkedBlockingDeque:
Program 1:
import java.util.concurrent.LinkedBlockingDeque;
import java.util.*;
public class GFG {
public static void main(String[] args)
throws InterruptedException
{
LinkedBlockingDeque<Integer> LBD
= new LinkedBlockingDeque<Integer>();
LBD.add( 7855642 );
LBD.add( 35658786 );
LBD.add( 5278367 );
LBD.add( 74381793 );
System.out.println( "Linked Blocking Deque: " + LBD);
System.out.println( "Head of Linked Blocking Deque: "
+ LBD.take());
System.out.println( "Linked Blocking Deque: " + LBD);
}
}
|
Output:
Linked Blocking Deque: [7855642, 35658786, 5278367, 74381793]
Head of Linked Blocking Deque: 7855642
Linked Blocking Deque: [35658786, 5278367, 74381793]
Program 2: To demonstrate InterruptedException
import java.util.concurrent.LinkedBlockingDeque;
import java.util.*;
public class GFG {
public static void main(String[] args)
throws InterruptedException
{
LinkedBlockingDeque<Integer> LBD
= new LinkedBlockingDeque<Integer>();
System.out.println( "Linked Blocking Deque: " + LBD);
try {
System.out.println( "Head of Linked Blocking Deque: "
+ LBD.take());
}
catch (Exception e) {
System.out.println( "Exception: " + e);
}
}
}
|
RuntimeException:
Max real time limit exceeded due to either by heavy load on server or by using sleep function.
Reference: https://docs.oracle.com/javase/8/docs/api/java/util/concurrent/LinkedBlockingDeque.html#take–
Share your thoughts in the comments
Please Login to comment...