您的位置:首页 > 编程语言 > C语言/C++

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

2015-07-04 21:49 351 查看
这个错误主要原因是出在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;
}
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: