数据越界等会报出std::out_of_range异常。
只有很少的情况下范围检查才是不可避免的。在这些情况下,STL 容器提供一个更加安全(但是速度也更慢)的方法来访问元素,即 at() 成员函数。at() 在功能上与重载的 [] 操作符很相似,但是它执行范围检查。如果参数是无效的,at() 就抛出一个 std::out_of_range 异常。因此,我们应该总是将 at() 调用包围在一个 try 代码块中,并提供一个与之匹配的 catch() 子句:
void assign(std::string & s, int index, char val)
{
try
{
s.at(index)=val;
}
catch (std::out_of_range & exc)
{
std::cerr <<exc.what();
}
}
总之,使用 [] 操作符访问容器元素的效率是很高的,如果范围检查不可避免,那么可以使用 at() 替代操作符 []。记住,在这种情况下一定要把对 at() 函数的调用包围在一个 try 代码块中并提供一个匹配的 catch() 子句。
只有很少的情况下范围检查才是不可避免的。在这些情况下,STL 容器提供一个更加安全(但是速度也更慢)的方法来访问元素,即 at() 成员函数。at() 在功能上与重载的 [] 操作符很相似,但是它执行范围检查。如果参数是无效的,at() 就抛出一个 std::out_of_range 异常。因此,我们应该总是将 at() 调用包围在一个 try 代码块中,并提供一个与之匹配的 catch() 子句:
void assign(std::string & s, int index, char val)
{
try
{
s.at(index)=val;
}
catch (std::out_of_range & exc)
{
std::cerr <<exc.what();
}
}
总之,使用 [] 操作符访问容器元素的效率是很高的,如果范围检查不可避免,那么可以使用 at() 替代操作符 []。记住,在这种情况下一定要把对 at() 函数的调用包围在一个 try 代码块中并提供一个匹配的 catch() 子句。