【C++】vector的迭代器使用中出现的程序中断

目的:

STL在很久以前就在使用了,当时记得是做一个基于OPENCV图像处理库,主要由C++编写的小游戏,STL用于处理游戏中的角色的死亡和添加、遍历,在那款游戏的设计中,STL并没有涉及到很细致的部分,但在最近进行一个需要大批量地使用STL的时候出现了很多的错误,重新细致地翻阅了c++Primer 之后,现在将错误进行总结并说明为何出错和如何改正。

随机访问容器如vector和list,在迭代器遍历过程中容易出现的错误:

大量问题主要出现在没有对容器的实现原理进行全面地了解

1.在迭代过程中erase一个容器中的元素,会让程序中断

错误代码:
vector ints;
	for(int i = 0; i < 100; i++){
		ints.push_back(i);
	}
	for (auto it = ints.cbegin(); it != ints.cend(); it++){
		if ((*it) % 2 == 0){
			ints.erase(it);
		}
	}
运行这个函数会让程序崩溃,具体原因是因为在erase成功之后,会让当前容器指向的所有迭代器失效,这时我们需要的是将此迭代器进行刷新,令其重新生效。
具体实现:
it = ints.erase(it);
容器的erase()操作不仅会删除容器中此迭代器指向的数据,还会返回指向此容器下一个数据的迭代器。
所以我们在处理的时候若想不出错,应使用如下代码:
for (auto it = ints.cbegin(); it != ints.cend();){
		if ((*it) % 2 == 0){
			it = ints.erase(it);
		}
		else{
			it++;
		}
	}

2.在迭代过程中push_back()操作有时候会导致程序中断

错误代码:
for (auto it = ints.cbegin(); it != ints.cend();){
		for (int i = 0; i < 100; i++){
			ints.push_back(i);
		}
	}
原因在于容器的存储原理是容器会在当前存储数据数量的基础上预留一定的内存来存储将要放下的数据,如果现在数据数量超过预留内存,容器将会在内存中重新开辟一块更大的内存,然后将自身复制到新内存中,并销毁现在所在的内存数据。这会导致容器的begin()和end()失效,当然迭代器也会失效。
我们有两种方法解决这个问题:
第一:可以容器名.reserve(预留数据量),将预留数据量改到足够大可以够程序使用,容器就不会重新开辟内存
vector ints;
	ints.reserve(1000);
	for (auto it = ints.cbegin(); it != ints.cend();){
			if (ints.size() == ints.capacity()){
				break;
			}
		}

 第二:在程序中设置中断,在判断到 
   
if (ints.size() == ints.capacity()){
				break;
			}
上面的代码大家应该能够看懂,不多说,可以根据具体情况进行自由发挥。今天先写到这些。


你可能感兴趣的:(C++)