使用vector push_back分配内存
Memory allocation with vector push_back
我今天学到了一些有趣的东西:如果我有一个标准向量v,我运行这样的代码:
std::vector<float> v;
for (int i = 0; i < 2; i++) v.push_back(2.);
如果我调用v[2]
,我不会得到分割错误,因为operator[]
不做边界检查。我得到了一个非常小的数字,但我很好奇push_back的默认行为是什么,以及我应该从溢出向量边界中得到什么。我认为它必须分配比下一个浮点数更多的空间。多少钱?这是在标准中,还是特定于编译器?
我今天学到了一些有趣的东西
所以是时候学习更有趣的东西了:你的代码有未定义行为,因为使用下标操作符的先决条件是索引小于vector的大小。
根据c++ 11标准表101,表达式a[n]
等价于*(a.begin() + n)
。由于v.begin() + 2
是指向容器v
末尾以外位置的迭代器,对其解引用将导致未定义行为。
如果我调用
v[2]
,我不会得到一个分割错误,因为operator[]
不做边界检查
这两个不是这样的关系…
你的代码调用未定义行为,所以它可以做任何事情
相关文章:
- 在c++中为我自己的基于指针的数组分配内存的正确方法
- 给定一个指向堆分配内存的指针,智能指针实现如何为其找到合适的释放函数?
- 如果 const 不分配内存,为什么我可以获取 const 的地址?
- 在函数中分配内存时出现问题
- 如何为 std::vector 分配内存,然后稍后为某些元素调用构造函数?
- constexpr new 如何分配内存?
- 在构造函数中分配内存失败是如何冒泡的
- LLVM 传递以在特定地址分配内存
- CudaMalloc 在分配内存时失败
- 为什么它在不分配内存的情况下工作正常
- 为什么在正确解除分配内存时出现内存泄漏?
- 如何通过 malloc 为队列数组分配内存?
- vector是否为std::移动的对象连续分配内存
- 删除类成员的动态分配内存的最佳方法是什么
- 唯一指针是否在堆或堆栈上分配内存?
- 如果不分配内存,我如何能够为变量创建和分配值?
- std::initializer_list 堆是否分配内存?
- 如何按顺序或在指定的地址分配内存?
- 是否可以使用 malloc 为类对象分配内存?
- 迭代器是否分配内存(如指针)?