 
- C++ Library - Home
- C++ Library - <fstream>
- C++ Library - <iomanip>
- C++ Library - <ios>
- C++ Library - <iosfwd>
- C++ Library - <iostream>
- C++ Library - <istream>
- C++ Library - <ostream>
- C++ Library - <sstream>
- C++ Library - <streambuf>
- C++ Library - <atomic>
- C++ Library - <complex>
- C++ Library - <exception>
- C++ Library - <functional>
- C++ Library - <limits>
- C++ Library - <locale>
- C++ Library - <memory>
- C++ Library - <new>
- C++ Library - <numeric>
- C++ Library - <regex>
- C++ Library - <stdexcept>
- C++ Library - <string>
- C++ Library - <thread>
- C++ Library - <tuple>
- C++ Library - <typeinfo>
- C++ Library - <utility>
- C++ Library - <valarray>
- The C++ STL Library
- C++ Library - <array>
- C++ Library - <bitset>
- C++ Library - <deque>
- C++ Library - <forward_list>
- C++ Library - <list>
- C++ Library - <map>
- C++ Library - <multimap>
- C++ Library - <queue>
- C++ Library - <priority_queue>
- C++ Library - <set>
- C++ Library - <stack>
- C++ Library - <unordered_map>
- C++ Library - <unordered_set>
- C++ Library - <vector>
- C++ Library - <algorithm>
- C++ Library - <iterator>
- The C++ Advanced Library
- C++ Library - <any>
- C++ Library - <barrier>
- C++ Library - <bit>
- C++ Library - <chrono>
- C++ Library - <cinttypes>
- C++ Library - <clocale>
- C++ Library - <condition_variable>
- C++ Library - <coroutine>
- C++ Library - <cstdlib>
- C++ Library - <cstring>
- C++ Library - <cuchar>
- C++ Library - <charconv>
- C++ Library - <cfenv>
- C++ Library - <cmath>
- C++ Library - <ccomplex>
- C++ Library - <expected>
- C++ Library - <format>
- C++ Library - <future>
- C++ Library - <flat_set>
- C++ Library - <flat_map>
- C++ Library - <filesystem>
- C++ Library - <generator>
- C++ Library - <initializer_list>
- C++ Library - <latch>
- C++ Library - <memory_resource>
- C++ Library - <mutex>
- C++ Library - <mdspan>
- C++ Library - <optional>
- C++ Library - <print>
- C++ Library - <ratio>
- C++ Library - <scoped_allocator>
- C++ Library - <semaphore>
- C++ Library - <source_location>
- C++ Library - <span>
- C++ Library - <spanstream>
- C++ Library - <stacktrace>
- C++ Library - <stop_token>
- C++ Library - <syncstream>
- C++ Library - <system_error>
- C++ Library - <string_view>
- C++ Library - <stdatomic>
- C++ Library - <variant>
- C++ STL Library Cheat Sheet
- C++ STL - Cheat Sheet
- C++ Programming Resources
- C++ Programming Tutorial
- C++ Useful Resources
- C++ Discussion
C++ Library - <queue>
Introduction to queue
Queue is a data structure designed to operate in FIFO (First in First out) context. In queue elements are inserted from rear end and get removed from front end.
Queue class is container adapter. Container is an objects that hold data of same type. Queue can be created from different sequence containers. Container adapters do not support iterators therefore we cannot use them for data manipulation. However they support push() and pop() member functions for data insertion and deletion respectively.
Definition
Below is definition of std::queuer from <queue> header file
template <class T, class Container = deque<T> > class queue;
Parameters
- 
T − Type of the element contained. T may be substituted by any other data type including user-defined type. 
- Container − Type of the underlying container object. 
Member types
Following member types can be used as parameters or return type by member functions.
| Sr.No. | Member types | Definition | 
|---|---|---|
| 1 | value_type | T (First parameter of the template) | 
| 2 | container_type | Second parameter of the template | 
| 3 | size_type | size_t | 
| 4 | reference | value_type& | 
| 5 | const_reference | const value_type& | 
| 6 | difference_type | ptrdiff_t | 
Functions from <queue>
Below is list of all methods from <queue> header.
Constructors
| Sr.No. | Method & Description | 
|---|---|
| 1 | queue::queue Constructs an empty queue object, with zero elements. | 
Destructor
| Sr.No. | Method & Description | 
|---|---|
| 1 | queue::~queue Destroys queue by deallocating container memory. | 
Member functions
| Sr.No. | Method & Description | 
|---|---|
| 1 | queue::back Returns a reference to the last element of queue. | 
| 2 | queue::emplace Constructs and inserts new element at the end of queue. | 
| 3 | queue::empty Tests whether queue is empty or not. | 
| 4 | queue::front Returns a reference to the first element of the queue. | 
| 5 | queue::operator= Assigns new contents to the queue by replacing old ones. | 
| 6 | queue::pop Removes front element of the queue. | 
| 7 | queue::push Inserts new element at the end of queue. | 
| 8 | queue::size Returns the total number of elements present in the queue. | 
| 9 | queue::swap Exchanges the contents of queue with contents of another queue. | 
Non-member overloaded functions
| Sr.No. | Method & Description | 
|---|---|
| 1 | operator== Tests whether two queues are equal or not. | 
| 2 | operator!= Tests whether two queues are equal or not. | 
| 3 | operator< Tests whether first queue is less than other or not. | 
| 4 | operator<= Tests whether first queue is less than or equal to other or not. | 
| 5 | operator> Tests whether first queue is greater than other or not. | 
| 6 | operator>= Tests whether first queue is greater than or equal to other or not. |