Skip to content
geeksforgeeks
  • Tutorials
    • Python
    • Java
    • Data Structures & Algorithms
    • ML & Data Science
    • Interview Corner
    • Programming Languages
    • Web Development
    • CS Subjects
    • DevOps And Linux
    • School Learning
    • Practice Coding Problems
  • Courses
    • DSA to Development
    • Get IBM Certification
    • Newly Launched!
      • Master Django Framework
      • Become AWS Certified
    • For Working Professionals
      • Interview 101: DSA & System Design
      • Data Science Training Program
      • JAVA Backend Development (Live)
      • DevOps Engineering (LIVE)
      • Data Structures & Algorithms in Python
    • For Students
      • Placement Preparation Course
      • Data Science (Live)
      • Data Structure & Algorithm-Self Paced (C++/JAVA)
      • Master Competitive Programming (Live)
      • Full Stack Development with React & Node JS (Live)
    • Full Stack Development
    • Data Science Program
    • All Courses
  • Java Arrays
  • Java Strings
  • Java OOPs
  • Java Collection
  • Java 8 Tutorial
  • Java Multithreading
  • Java Exception Handling
  • Java Programs
  • Java Project
  • Java Collections Interview
  • Java Interview Questions
  • Java MCQs
  • Spring
  • Spring MVC
  • Spring Boot
  • Hibernate
Open In App
Next Article:
PriorityBlockingQueue offer() method in Java
Next article icon

PriorityBlockingQueue offer() method in Java

Last Updated : 29 Jun, 2022
Comments
Improve
Suggest changes
Like Article
Like
Report

1. offer(E e) Method

The offer(E e) method of PriorityBlockingQueue inserts the element e, passed as parameter, in this PriorityBlockingQueue.This method inserts the element into this PriorityBlockingQueue. Since the PriorityBlockingQueue is unbounded, this method will be never be blocked. Syntax:

public boolean offer(E e)

Parameter: This method accepts one parameter e which represents the element e we want to insert in this PriorityBlockingQueue. Returns: This method returns boolean response true if insertion is successful. Exception: This method throws following Exceptions.

  • ClassCastException – if the specified element cannot be compared with elements currently in the priority queue according to the PriorityBlockingQueue’s ordering.
  • NullPointerException– if the element is null

Below programs illustrate offer() method of PriorityBlockingQueue: Example 1: Program to demonstrate offer() method on PriorityBlockingQueue to add a list of numbers. 

Java
// Java Program Demonstrate offer() // method of PriorityBlockingQueue  import java.util.concurrent.PriorityBlockingQueue;  public class GFG {     public static void main(String[] args)     {          // define capacity of PriorityBlockingQueue         int capacityOfQueue = 5;          // create object of PriorityBlockingQueue         PriorityBlockingQueue<Integer> PrioQueue             = new PriorityBlockingQueue<Integer>(capacityOfQueue);          // Add numbers to PriorityBlockingQueue using offer()         PrioQueue.offer(35658786);         PrioQueue.offer(5278367);         PrioQueue.offer(74381793);         PrioQueue.offer(87625142);          // print elements of PriorityBlockingQueue         System.out.println("Queue Contains:");         System.out.println(PrioQueue.toString());     } } 
Output:
Queue Contains: [5278367, 35658786, 74381793, 87625142]

Example 2: Program to demonstrate Exception thrown by offer() method when we try to add null to PriorityBlockingQueue. 

Java
// Java Program Demonstrate offer() // method of PriorityBlockingQueue  import java.util.concurrent.PriorityBlockingQueue; import java.util.*;  public class GFG {     public static void main(String[] args)     {          // define capacity of PriorityBlockingQueue         int capacityOfQueue = 5;          // create object of PriorityBlockingQueue which contains         // name of students         PriorityBlockingQueue<String> names             = new PriorityBlockingQueue<String>(capacityOfQueue);          // Add names of students of girls college         names.offer("Joyita");         names.offer("Priyanka");          // try to insert null value in offer method         try {             names.offer(null);         }         catch (Exception e) {             // print error details             System.out.println("Exception Thrown: " + e);         }     } } 
Output:
Exception Thrown: java.lang.NullPointerException

2. offer(E e, long timeout, TimeUnit unit) Method

The offer(E e, long timeout, TimeUnit unit) method of PriorityBlockingQueue inserts the element e, passed as parameter, in this PriorityBlockingQueue.This method inserts the element into this PriorityBlockingQueue. Since the PriorityBlockingQueue is unbounded, this method will be never be blocked and timeout and timeUnit parameters are neglected.This method is inherited from superclass of priorityBlockingQueue which is BlockingQueue class But as priorityBlockingQueue never blocks new element to be inserted so this method inherited from super class is logically same as offer(E e) method. Syntax:

offer(E e, long timeout, TimeUnit unit)

Parameter: This method accepts three parameters

  1. e : the element to be inserted in PriorityBlockingQueue.
  2. timeout : this parameter is neglected because queue never blocks new element insertion.
  3. unit : this parameter is also neglected because queue never blocks new element insertion.

Returns: This method returns boolean response true if insertion is successful. Exception: This method throws following Exceptions.

  • ClassCastException – if the specified element cannot be compared with elements currently in the priority queue according to the PriorityBlockingQueue’s ordering.
  • NullPointerException– if the element is null

Below programs illustrate offer(E e, long timeout, TimeUnit unit) method of PriorityBlockingQueue: Example 1: Program to demonstrate offer(E e, long timeout, TimeUnit unit) method on PriorityBlockingQueue to add a list of numbers. 

Java
// Java Program Demonstrate offer() // method of PriorityBlockingQueue  import java.util.concurrent.PriorityBlockingQueue; import java.util.concurrent.TimeUnit;  public class GFG {     public static void main(String[] args)     {          // define capacity of PriorityBlockingQueue         int capacityOfQueue = 5;          // create object of PriorityBlockingQueue         PriorityBlockingQueue<Integer> PrioQueue             = new PriorityBlockingQueue<Integer>(capacityOfQueue);          // Add 3 elements to PriorityBlockingQueue using         // offer(Element e, long timeout, TimeUnit unit)         System.out.println("adding 1234 "                            + PrioQueue.offer(1234,                                              5, TimeUnit.SECONDS));         System.out.println("adding 2345 "                            + PrioQueue.offer(2345,                                              5, TimeUnit.SECONDS));         System.out.println("adding 3456 "                            + PrioQueue.offer(3456,                                              5, TimeUnit.SECONDS));          // print elements of PriorityBlockingQueue         System.out.println("Queue Contains:");         System.out.println(PrioQueue.toString());     } } 
Output:
adding 1234 true adding 2345 true adding 3456 true Queue Contains: [1234, 2345, 3456]

Reference:

  • https://docs.oracle.com/javase/8/docs/api/java/util/concurrent/PriorityBlockingQueue.html#offer-E-
  • https://docs.oracle.com/javase/8/docs/api/java/util/concurrent/PriorityBlockingQueue.html#offer-E-long-java.util.concurrent.TimeUnit-

Next Article
PriorityBlockingQueue offer() method in Java

A

AmanSingh2210
Improve
Article Tags :
  • Java
  • Java-Collections
  • Java - util package
  • java-basics
  • Java-Functions
  • Java-PriorityBlockingQueue
Practice Tags :
  • Java
  • Java-Collections

Similar Reads

    PriorityBlockingQueue peek() method in Java
    The peek() method of PriorityBlockingQueue returns the element at head of the PriorityBlockingQueue. It retrieves the value of the head of LinkedBlockingQueue but does not remove it. If the PriorityBlockingQueue does not contains any element, then this method returns null. A PriorityBlockingQueue qu
    2 min read
    PriorityBlockingQueue poll() method in Java
    1. poll() Method The poll() method of PriorityBlockingQueue retrieves and removes element from head of this PriorityBlockingQueue. This method returns the element it removes from PriorityBlockingQueue but when the queue is empty then method will return null. Syntax: public E poll() Returns: This met
    4 min read
    PriorityQueue offer() Method in Java
    The java.util.PriorityQueue.offer() method is used to insert a particular element into the Priority Queue. It acts similar to the add() method of Priority Queue. Syntax: Priority_Queue.offer(Object element) Parameters: The parameter element is of the type PriorityQueue and refers to the element to b
    2 min read
    PriorityBlockingQueue add() Method in Java
    The add(E e) method of PriorityBlockingQueue inserts the element passed as a parameter to the method at the tail of this PriorityBlockingQueue. This method returns true if the adding of the element is successful. Else it returns false. Syntax: public boolean add(E e) Parameter: This method takes a m
    2 min read
    PriorityBlockingQueue put() method in Java
    The put(E e) method of PriorityBlockingQueue is used to add an element into this queue. This method inserts the specified element into this priority queue. Since the queue is unbounded, this method will be never be blocked.Syntax: public void put(E e) Parameter: This method accepts a mandatory param
    2 min read
geeksforgeeks-footer-logo
Corporate & Communications Address:
A-143, 7th Floor, Sovereign Corporate Tower, Sector- 136, Noida, Uttar Pradesh (201305)
Registered Address:
K 061, Tower K, Gulshan Vivante Apartment, Sector 137, Noida, Gautam Buddh Nagar, Uttar Pradesh, 201305
GFG App on Play Store GFG App on App Store
Advertise with us
  • Company
  • About Us
  • Legal
  • Privacy Policy
  • In Media
  • Contact Us
  • Advertise with us
  • GFG Corporate Solution
  • Placement Training Program
  • Languages
  • Python
  • Java
  • C++
  • PHP
  • GoLang
  • SQL
  • R Language
  • Android Tutorial
  • Tutorials Archive
  • DSA
  • Data Structures
  • Algorithms
  • DSA for Beginners
  • Basic DSA Problems
  • DSA Roadmap
  • Top 100 DSA Interview Problems
  • DSA Roadmap by Sandeep Jain
  • All Cheat Sheets
  • Data Science & ML
  • Data Science With Python
  • Data Science For Beginner
  • Machine Learning
  • ML Maths
  • Data Visualisation
  • Pandas
  • NumPy
  • NLP
  • Deep Learning
  • Web Technologies
  • HTML
  • CSS
  • JavaScript
  • TypeScript
  • ReactJS
  • NextJS
  • Bootstrap
  • Web Design
  • Python Tutorial
  • Python Programming Examples
  • Python Projects
  • Python Tkinter
  • Python Web Scraping
  • OpenCV Tutorial
  • Python Interview Question
  • Django
  • Computer Science
  • Operating Systems
  • Computer Network
  • Database Management System
  • Software Engineering
  • Digital Logic Design
  • Engineering Maths
  • Software Development
  • Software Testing
  • DevOps
  • Git
  • Linux
  • AWS
  • Docker
  • Kubernetes
  • Azure
  • GCP
  • DevOps Roadmap
  • System Design
  • High Level Design
  • Low Level Design
  • UML Diagrams
  • Interview Guide
  • Design Patterns
  • OOAD
  • System Design Bootcamp
  • Interview Questions
  • Inteview Preparation
  • Competitive Programming
  • Top DS or Algo for CP
  • Company-Wise Recruitment Process
  • Company-Wise Preparation
  • Aptitude Preparation
  • Puzzles
  • School Subjects
  • Mathematics
  • Physics
  • Chemistry
  • Biology
  • Social Science
  • English Grammar
  • Commerce
  • World GK
  • GeeksforGeeks Videos
  • DSA
  • Python
  • Java
  • C++
  • Web Development
  • Data Science
  • CS Subjects
@GeeksforGeeks, Sanchhaya Education Private Limited, All rights reserved
We use cookies to ensure you have the best browsing experience on our website. By using our site, you acknowledge that you have read and understood our Cookie Policy & Privacy Policy
Lightbox
Improvement
Suggest Changes
Help us improve. Share your suggestions to enhance the article. Contribute your expertise and make a difference in the GeeksforGeeks portal.
geeksforgeeks-suggest-icon
Create Improvement
Enhance the article with your expertise. Contribute to the GeeksforGeeks community and help create better learning resources for all.
geeksforgeeks-improvement-icon
Suggest Changes
min 4 words, max Words Limit:1000

Thank You!

Your suggestions are valuable to us.

What kind of Experience do you want to share?

Interview Experiences
Admission Experiences
Career Journeys
Work Experiences
Campus Experiences
Competitive Exam Experiences