C++ primer 当vector中的push_back遇到移动构造函数会发生什么

本文详细探讨了在C++中,当使用`vector`的`push_back`方法时,如何与移动构造函数交互。C++11规定移后源对象必须处于可析构状态。如果类定义了移动构造函数,`push_back`可能导致内存重新分配,触发移动构造函数。默认初始化的`vector`在需要时会分配新空间,导致移动构造函数的调用,但预先预留空间则可避免。文章通过实例代码展示了不同情况下的析构过程。
摘要由CSDN通过智能技术生成

首先仔细阅读 C++ primer 第五版 P474 Note下面的一段话

意思是说当我们在类中定义了移动构造函数的时候,假设这个移动构造函数是noexcept的,类似对应StrVec类的操作,vector可能会重新分配内存,也就是说会将元素从旧空间移动到新内存中去。这个过程中就会发生移动构造函数


注意
这里要注意一点,C++11规定的是移后源对象是一定要处于可析构的状态,意思是说移后源对象有可能执行析构函数,也有可能不执行析构函数,主要要看这个源对象在这个作用域生命周期是否结束吗,以下有例子可以说明。

默认初始化的vector是不分配内存空间的,当push_back发现vector空间不足以容纳新元素时,就会分配新的空间(通常是加倍),将数据移动到新空间时就会发生移动构造函数,而当我们用vs.reserve()预留足够的空间时,就不会发生移动构造函数了。

例子

使用C++ primer 中的String类,这里我使用MyString ,内容几乎一样。

1.代码如下:

int main()
{
    MyString s1("FOne"), s2("Two");
    vector<MyString> msvec;
    msvec.push_back(s1);
    msvec.push_back(s2);
    //msvec.push_bac
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值