C++ Reference: Standard C++ Library reference: Containers: deque: deque: emplace

C++官网参考链接:https://cplusplus.com/reference/deque/deque/emplace/

公有成员函数 
<deque>
std::deque::emplace
template <class... Args>  iterator emplace (const_iterator position, Args&&... args);
构造并插入元素
通过在position上插入一个新元素来扩展容器。这个新元素是使用args作为构造它的实参来就地构造的。
这有效地将容器的size增加了1。
deque设计为从序列的结束或开始高效地执行插入(和删除)。在其他位置插入通常比在listforward_list容器中效率低。请参阅emplace_frontemplace_back,了解在开始或结束直接扩展容器的成员函数。
元素是通过使用转发的args调用allocator_traits::construct就地构造的。

形参 
position 
插入新元素的容器中的位置。
成员类型const_iterator是一个指向const元素的随机访问iterator(random access iterator)类型。
args
用来构造新元素而转发的实参。

返回值
指向新插入元素的iterator。
成员类型iterator是指向元素的随机访问iterator(random access iterator)类型。
新元素的存储是使用allocator_traits<allocator_type>::construct()分配的,它可能在失败时抛出异常(对于默认的allocator,如果分配请求不成功,则抛出bad_alloc)。

用例
// deque::emplace
#include <iostream>
#include <deque>

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

  auto it = mydeque.emplace ( mydeque.begin()+1, 100 );
  mydeque.emplace ( it, 200 );
  mydeque.emplace ( mydeque.end(), 300 );

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

  return 0;
}
输出:

复杂度
根据特定的库实现,最高达到在positiondeque结束之一之间的元素数量中的线性。 

iterator的有效性
如果插入发生在序列的开始或结束处,则与此容器相关的所有iterator都将失效,但指针和reference仍然有效,指向调用之前所引用的相同元素。
如果插入发生在deque的其他位置,则与此容器相关的所有iterator、指针和reference都将失效。

数据竞争
完成容器的修改。
如果插入发生在序列的开始或结束处,则不会访问所包含的元素(参见上面的iterator的有效性)。
如果它发生在其他地方,同时访问元素是不安全的。

异常安全
如果positionbeginend,则在异常情况下容器中不存在任何更改(强保证)。
否则,保证容器以有效状态结束(基本保证)。
如果适当的实参不支持allocator_traits::construct,或者position无效,则会导致未定义的行为。 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

weixin_40186813

你的能量无可限量。

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值