C++向量的奇怪行为
C++ vector strange behaviour
考虑这个程序:
#include <iostream>
#include <vector>
using namespace std;
int main(void)
{
vector<double> a;
while (a.size() <= 10)
a.push_back(2);
cout << a[15] << endl;
}
当被要求访问a的第15个元素时,我预计它会崩溃,但它没有(在我的系统上输出0)。什么东西?这是gcc中的一些新功能吗?
您正在访问一个无效的内存位置,这会导致未定义的行为。所以任何事情都有可能发生。
这个引用说它是
返回对向量中位置n处元素的引用容器
类似的成员函数vector::at具有与以下相同的行为运算符函数,如果请求抛出异常导致位置超出范围。
所以,这可能会崩溃,也可能不会崩溃。
operator[]
不进行边界检查,在这种情况下,您运气不好,可以读取该位置的地址而不会导致运行时错误。
因为访问向量时,向量的增长可能大于15?
检查capacity()
。
这并不奇怪。。当插入一个size()-1元素时,向量的大小会增加。。现在你有20个元素。。(可能不是20,但超过11(=)
I您正在读取的内存在程序中,它不会崩溃,c++不限制检查
相关文章:
- 写入向量<向量<bool>>
- 函数向量_指针有不同的原型,我可以构建一个吗
- std::向量与传递值的动态数组
- 将值指定给向量(2D)的向量中的某个位置
- 找不到成员对象:没有名为get_event()的成员,也处理多态性和向量
- 如何使用向量的template_back函数
- 尝试通过多个向量访问变量时,向量下标超出范围
- 如何通过派生类函数更改基类中的向量
- C++从另一个类访问公共静态向量的正确方法是什么
- 如何将ampl中的集合表示为c++中的向量
- 变量没有改变?通过向量的函数调用
- 迭代时从向量和内存中删除对象
- 向量 <int> a {N, 0} 和 int arr a[N] = {0} 的时间复杂度有什么区别
- 如何为模板化对象创建模板向量?VS正在投掷C3203
- 计算排序向量的向量中唯一值的计数
- 矩阵向量乘法(cublasDgemv)返回零
- 一对向量构造函数:初始值设定项列表与显式构造
- 将结构向量排序为子组
- 在C++中调整向量中的索引
- 向量元素的引用地址与它所指向的向量元素的地址不同.为什么