C++ Deque 库 - emplace() 函数


描述

C++ 函数std::deque::emplace()通过在位置插入新元素来扩展 deque 。如果发生重新分配,则该容器的存储要求由内部分配器满足。

宣言

以下是 std::deque::emplace() 函数形式 std::deque 标头的声明。

C++11

template <class... Args>
iterator emplace (const_iterator position, Args&&... args);

参数

  • position - 双端队列中要插入新元素的索引。

  • args - 转发以构造新元素的参数。

返回值

返回一个随机访问迭代器,它指向新放置的元素。

例外情况

如果重新分配失败,则会抛出bad_alloc异常。

时间复杂度

线性即 O(n)

例子

以下示例显示了 std::deque::emplace() 函数的用法。

#include <iostream>
#include <deque>

using namespace std;

int main(void) {

   deque<int> d = {1, 2, 5};

   auto it = d.emplace(d.begin() + 2, 3);

   d.emplace(it, 4);

   cout << "Contents of deque are" << endl;

   for (auto it = d.crend() - 1; it >= d.crbegin(); --it)
      cout << *it << endl;

   return 0;
}

让我们编译并运行上面的程序,这将产生以下结果 -

Contents of deque are
1
2
4
3
5
双端队列.htm