Home C&C++函数库 c++ 语法 程序源码 Linux C库

std::

deque::emplace_back

公众成员函数  <deque>
template <class... Args>
  void emplace_back (Args&&... args);
构造并在末尾插入元素
在deque容器的末尾插入一个新元素,就在当前最后一个元素的后面。这个新元素使用args作为其构造的参数构造。

容器大小加1.

元素是通过调用allocator_traits::construct和转发的参数构造的。

存在一个类似的成员函数push_back,它将现有对象复制或移动到容器中。

☲  参数


args
为构造新元素而传递的参数。

☉  返回值



none
新元素的存储是使用allocator_traits<allocator_type>::construct()分配的, 如果失败,可能会抛出异常(对于默认的分配器,如果分配请求不成功,会抛出bad_alloc)。

☣  示例



// deque::emplace_from
#include <iostream>
#include <deque>

int main ()
{
  std::deque<int> mydeque = {10,20,30};

  mydeque.emplace_back (100);
  mydeque.emplace_back (200);

  std::cout << "mydeque contains:";
  for (auto& x: mydeque)
    std::cout << ' ' << x;
  std::cout << '\n';

  return 0;
}

输出:
mydeque contains: 10 20 30 100 200

✥ 复杂度



常量

☣ 迭代器的有效性



与该容器相关的所有迭代器都失效,但指针和引用仍然有效,它们引用的元素与调用前相同。

⇄ 数据竞争


容器被修改。
调用不会访问所包含的元素:并发访问或修改它们是安全的(请参阅上面的迭代器有效性)。

☂ 异常安全性



强保证:如果抛出异常,容器中没有任何变化。
如果不支持allocator_traits::construct,则会导致未定义的行为。

🍄  另请参阅



deque::erase 删除元素(公众成员函数)
deque::emplace 构造并插入元素 (公众成员函数)
deque::emplace_front 构造并在开头插入元素 (公众成员函数)
deque::assign 分配容器的内容 (公众成员函数)
deque::pop_back 删除最后一个元素 (公众成员函数)

联系我们 免责声明 关于CandCplus 网站地图