|
| | deque () |
| | 默认构造函数
|
| | deque (const size_type n) |
| | 构造包含n个默认构造元素的双端队列
|
| | deque (const size_type n, const T &value) |
| | 构造包含n个指定值元素的双端队列
|
| template<typename Iterator, enable_if_t< is_iter_v< Iterator >, int > = 0> |
| | deque (Iterator first, Iterator last) |
| | 范围构造函数
|
| | deque (std::initializer_list< T > ilist) |
| | 初始化列表构造函数
|
| deque & | operator= (std::initializer_list< T > ilist) |
| | 初始化列表赋值运算符
|
| | deque (const deque &other) |
| | 拷贝构造函数
|
| deque & | operator= (const deque &other) |
| | 拷贝赋值运算符
|
| | deque (deque &&other) noexcept |
| | 移动构造函数
|
| deque & | operator= (deque &&other) noexcept |
| | 移动赋值运算符
|
| | ~deque () |
| | 析构函数
|
| NEFORCE_NODISCARD iterator | begin () noexcept |
| | 获取起始迭代器
|
| NEFORCE_NODISCARD iterator | end () noexcept |
| | 获取结束迭代器
|
| NEFORCE_NODISCARD const_iterator | begin () const noexcept |
| | 获取常量起始迭代器
|
| NEFORCE_NODISCARD const_iterator | end () const noexcept |
| | 获取常量结束迭代器
|
| NEFORCE_NODISCARD const_iterator | cbegin () const noexcept |
| | 获取常量起始迭代器
|
| NEFORCE_NODISCARD const_iterator | cend () const noexcept |
| | 获取常量结束迭代器
|
| NEFORCE_NODISCARD reverse_iterator | rbegin () noexcept |
| | 获取反向起始迭代器
|
| NEFORCE_NODISCARD reverse_iterator | rend () noexcept |
| | 获取反向结束迭代器
|
| NEFORCE_NODISCARD const_reverse_iterator | rbegin () const noexcept |
| | 获取常量反向起始迭代器
|
| NEFORCE_NODISCARD const_reverse_iterator | rend () const noexcept |
| | 获取常量反向结束迭代器
|
| NEFORCE_NODISCARD const_reverse_iterator | crbegin () const noexcept |
| | 获取常量反向起始迭代器
|
| NEFORCE_NODISCARD const_reverse_iterator | crend () const noexcept |
| | 获取常量反向结束迭代器
|
| NEFORCE_NODISCARD size_type | size () const noexcept |
| | 获取当前元素数量
|
| NEFORCE_NODISCARD size_type | max_size () const noexcept |
| | 获取最大可能大小
|
| NEFORCE_NODISCARD bool | empty () const noexcept |
| | 检查是否为空
|
| NEFORCE_NODISCARD reference | front () noexcept |
| | 访问第一个元素
|
| NEFORCE_NODISCARD const_reference | front () const noexcept |
| | 访问第一个常量元素
|
| NEFORCE_NODISCARD reference | back () noexcept |
| | 访问最后一个元素
|
| NEFORCE_NODISCARD const_reference | back () const noexcept |
| | 访问最后一个常量元素
|
| void | resize (size_type n, const T &value) |
| | 调整大小
|
| void | resize (const size_type n) |
| | 使用默认构造的元素调整大小
|
| template<typename... Args> |
| iterator | emplace (iterator position, Args &&... args) |
| | 在指定位置构造元素
|
| template<typename... Args> |
| void | emplace_back (Args &&... args) |
| | 在末尾构造元素
|
| template<typename... Args> |
| void | emplace_front (Args &&... args) |
| | 在开头构造元素
|
| void | push_back (const T &value) |
| | 在末尾拷贝插入元素
|
| void | push_front (const T &value) |
| | 在开头拷贝插入元素
|
| void | push_back (T &&value) |
| | 在末尾移动插入元素
|
| void | push_front (T &&value) |
| | 在开头移动插入元素
|
|
void | pop_back () noexcept(is_nothrow_destructible_v< value_type >) |
| | 移除末尾元素
|
|
void | pop_front () noexcept(is_nothrow_destructible_v< value_type >) |
| | 移除开头元素
|
| void | assign (const size_type count, const T &value) |
| | 赋值n个指定值的元素
|
| template<typename Iterator, enable_if_t< is_iter_v< Iterator >, int > = 0> |
| void | assign (Iterator first, Iterator last) |
| | 范围赋值
|
| void | assign (std::initializer_list< T > ilist) |
| | 初始化列表赋值
|
| iterator | insert (iterator position, const T &value) |
| | 在指定位置拷贝插入元素
|
| iterator | insert (iterator position, T &&value) |
| | 在指定位置移动插入元素
|
| template<typename Iterator, enable_if_t< is_iter_v< Iterator >, int > = 0> |
| void | insert (iterator position, Iterator first, Iterator last) |
| | 范围插入
|
| iterator | insert (iterator position, std::initializer_list< T > list) |
| | 初始化列表插入
|
| void | insert (iterator position, const size_t n, const T &value) |
| | 插入n个指定值的元素
|
| iterator | erase (iterator position) |
| | 删除指定位置的元素
|
| iterator | erase (iterator first, iterator last) |
| | 删除指定范围内的元素
|
| void | shrink_to_fit () noexcept(is_nothrow_destructible_v< value_type >) |
| | 收缩容量以适应当前大小
|
| void | clear () noexcept(is_nothrow_destructible_v< value_type >) |
| | 清空双端队列
|
| NEFORCE_NODISCARD const_reference | at (size_type position) const noexcept |
| | 带边界检查的常量索引访问
|
| NEFORCE_NODISCARD reference | at (const size_type position) noexcept |
| | 带边界检查的索引访问
|
| NEFORCE_NODISCARD const_reference | operator[] (const size_type position) const noexcept |
| | 常量下标访问操作符
|
| NEFORCE_NODISCARD reference | operator[] (const size_type position) noexcept |
| | 下标访问操作符
|
| void | swap (deque &other) noexcept(is_nothrow_swappable_v< map_allocator > &&is_nothrow_swappable_v< allocator_type >) |
| | 交换两个双端队列的内容
|
| NEFORCE_NODISCARD bool | operator== (const deque &rhs) const noexcept(noexcept(_NEFORCE equal(cbegin(), cend(), rhs.cbegin()))) |
| | 相等比较操作符
|
| NEFORCE_NODISCARD bool | operator< (const deque &rhs) const noexcept(noexcept(_NEFORCE lexicographical_compare(cbegin(), cend(), rhs.cbegin(), rhs.cend()))) |
| | 小于比较操作符
|
| NEFORCE_NODISCARD constexpr decltype(auto) | size () const noexcept(noexcept(derived().size())) |
| | 获取集合大小
|
| NEFORCE_NODISCARD constexpr bool | empty () const noexcept(noexcept(derived().empty())) |
| | 检查集合是否为空
|
| NEFORCE_NODISCARD constexpr bool | operator== (const T &rhs) const noexcept(noexcept(derived()==rhs)) |
| | 相等比较运算符
|
| NEFORCE_NODISCARD constexpr bool | operator!= (const T &rhs) const noexcept(noexcept(!(*this==rhs))) |
| | 不等比较运算符
|
| NEFORCE_NODISCARD constexpr bool | operator< (const T &rhs) const noexcept(noexcept(derived()< rhs)) |
| | 小于比较运算符
|
| NEFORCE_NODISCARD constexpr bool | operator> (const T &rhs) const noexcept(noexcept(rhs< derived())) |
| | 大于比较运算符
|
| NEFORCE_NODISCARD constexpr bool | operator<= (const T &rhs) const noexcept(noexcept(!(derived() > rhs))) |
| | 小于等于比较运算符
|
| NEFORCE_NODISCARD constexpr bool | operator>= (const T &rhs) const noexcept(noexcept(!(derived()< rhs))) |
| | 大于等于比较运算符
|
template<typename T, typename Alloc = allocator<T>,
size_t BufSize = 0>
class deque< T, Alloc, BufSize >
双端队列容器
- 模板参数
-
| T | 元素类型 |
| Alloc | 分配器类型 |
| BufSize | 缓冲区大小(0表示自动计算) |
双端队列是一种支持在两端高效插入和删除的序列容器。 采用分块存储结构:元素被分割成多个固定大小的缓冲区, 这些缓冲区的指针存储在中控器中,从而实现动态增长和两端操作。 提供随机访问迭代器,但迭代器可能因重新分配而失效。
在文件 deque.hpp 第 265 行定义.