【C++容器对类元素的初始化疑问】

#include <iostream>
#include <vector>
using namespace std;
struct X
{
	X() { cout << "构造" << endl; }
	X(const X&) { cout << "拷贝" << endl; }
	X& operator=(const X& x)
	{
		cout << "赋值" << endl;
		return *this;
	}
	~X() { cout << "析构" << endl; }
};
int main()
{
	X b;
	
	cout << endl;
	vector<X> vec;
	/*
    vec.push_back(b);
	cout << endl;
    */
	vec.push_back(b);
	system("pause");
	return 0;
}

这段代码运行显示如下:

但是如果把注释去掉,push_back(b)两次的话,第二次就会这样显示:

请问是什么原因?

题主这个问题我比较感兴趣,稍微的改造了一下方便分析:

img

img


我一开始怀疑是因为vector容器自主扩容有这个影响,加上跟踪之后发现容量没有突然变大,所以我又加了一次push 发现第三次 执行了两次拷贝和析构 我不禁有种怀疑 是不是每次push的过程 是重新开辟空间的过程 先将原有的 容器内数据 进行一份复制 再 添加新的数据,再将原有的析构掉。我是这种怀疑,呵呵呵。

img

抱着这种想法 我在前期resezi了一个5 我们知道vector容器有个特性是会根据当前容器的容量 有个提前开辟空间的功能 那么可与看到 空间容量是7 size是6 我再次push的时候 没有进行 构造和析构的过程,那么基本就可以肯定我之前的结论了。
即当push的时候 首先会判断容器的容量 是否和size 一样 如果容器的容量里有可用空间 直接push进去 如果没有可用空间 那么需要进行重新开辟空间 将原有的容器内元素 进行复制 push进新的元素 再将原容器销毁。