首先仔细阅读 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