at()提供边界检查并抛出异常,安全但稍慢;[]无检查,速度快但越界访问导致未定义行为,可能崩溃或数据损坏。
在C++中,vector 是最常用的动态数组容器之一。但在使用过程中,对元素的访问方式不同,其安全性和行为也大不相同。特别是越界访问(即访问不存在的索引),可能引发严重问题。下面详细说明 at() 与下标操作符 [] 的区别,以及越界访问的实际后果。
当通过下标操作符 [] 访问 vector 中一个超出有效范围的索引时,比如 v[100] 而 vector 实际只有10个元素,这种行为是未定义的(undefined behavior)。
这意味着:
由于没有边界检查,[] 操作非常快,但也因此不安全。
at() 和 [] 都用于访问 vector 元素,但关键区别在于是否进行边界检查。
1. at() 成员函数std::out_of_range 异常以下代码演示两者的不同表现:
std::vectorv = {1, 2, 3}; // 使用 at():会抛出异常 try { v.at(10) = 5; // 抛出 std::out_of_range } catch (const std::out_of_range& e) { std::cout << "错误: " << e.what() << std::endl; } // 使用 []:无提示,行为未定义 v[10] = 5; // 危险!可能导致崩溃或数据损坏
建议在开发和调试阶段优先使用 at(),便于及时发现索引错误;在性能敏感且索引确定合法的场景再使用 []。
i
for (size_t i = 0; i 而非硬编码长度
for (const auto& x : v)
assert(i
[] 做额外检查基本上就这些。关键是理解:安全和效率之间需要权衡,at() 提供安全,[] 提供速度。根据上下文选择合适的方式,能显著提升代码健壮性。