vector小小的缺陷

今天在使用vector的时候,遇见了一个问题,在定义迭代器并且将它指向容器front的时候并没有,立即使用它,而是在push几个元素之后,insert了一个元素,但是报了内存错误。

最后发现,vectot默认的数据容量每次只会开辟一个对应数据类型的存储空间,所以如果iterator不立即使用它的指向就是错的,迭代器会失效。

#include <iostream>
#include <vector>
using namespace std;
int main()
{
#if 1
	vector<int> test;
	vector<int>::iterator it;
	it = test.begin();
    it=test.insert(it,5);
   
	test.push_back(1);
	//test.push_back(2);
	//test.push_back(3);
	//test.push_back(4);
	it = test.begin();
	 it = test.insert(it, 88);
	 cout << test.size()<<endl;
	 cout << test.capacity() << endl;
	for (auto& v : test)
	{
		cout << v << ' ';
	}
#else
	vector<int> myvector(3, 100);
	vector<int>::iterator it;

	it = myvector.begin();
	it = myvector.insert(it, 200);

	myvector.insert(it, 2, 300);

	// "it" no longer valid, get a new one:
	it = myvector.begin();

	vector<int> anothervector(2, 400);
	myvector.insert(it + 2, anothervector.begin(), anothervector.end());

	int myarray[] = { 501,502,503 };
	myvector.insert(myvector.begin(), myarray, myarray + 3);

	cout << "myvector contains:";
	for (it = myvector.begin(); it < myvector.end(); it++)
		cout << " " << *it;
	cout << endl;

#endif
	system("pause"); 
	return 0;
}

发布了157 篇原创文章 · 获赞 98 · 访问量 3万+

猜你喜欢

转载自blog.csdn.net/weixin_43447989/article/details/102626155