C++ 顺序容器的安全随机访问

这个错误主要原因是出在STL上,比如[]越界等,所以重点要检查是不是那些操作超出了规定范围。具体还弄不是很清楚,原先我程序出现这个问题,后来发现是因为把空白符压进了vetor<string>中。具体还不清楚其越界的原因。在网上看到的一个解释感觉还可以帮助理解。
什么时候范围检查是不同避免的
    只有很少的情况下范围检查才是不可避免的。在这些情况下,STL 容器提供一个更加安全(但是速度也更慢)的方法来访问元素,即 at() 成员函数。at() 在功能上与重载的 [] 操作符很相似,但是它执行范围检查。如果参数是无效的,at() 就抛出一个 std::out_of_range 异常。因此,我们应该总是将 at() 调用包围在一个 try 代码块中,并提供一个与之匹配的 catch() 子句:
 
#include <iostream>
#include <string>
#include <vector>
using namespace std;

int main(int argc,char** argv)
{
	vector<string> svec;
	//cout << svec[0] << endl;
	try
	{
		cout  << svec.at(0) << endl;
	}catch(std::out_of_range & exc)
	{
		cout  << "svec expection empty" << endl;
	}
	system("pause");
	return 0;
}


你可能感兴趣的:(C++ 顺序容器的安全随机访问)