作者:朱金灿
来源:clever101的专栏
在对对vector元素取地址时需要考虑元素的地址是否发生了变化。比如下面代码:
std::vector<int> a;
a.push_back(0);
int* b = &a[0];
//在执行完下面代码,a[0]的地址已经发生了变化
for (int i = 0; i <100; ++i)
{
a.push_back(50);
}
为什么在执行多次push_back操作后a[0]的地址会发生变化?究其原因std::vector在执行push_back操作就是先估算已申请的内存是否够用,如果不够用就会重新申请一块内存,再把原来的内存复制一份的,这时每个元素的地址都会发生变化的。std::vector扩容机制取决于编译器类型:VS2015-----1.5倍扩容;g++编译器-------2倍扩容。因此在对vector元素取地址时必须慎重,必须确保所取得的是元素的有效地址。
本文探讨了为什么在多次调用std::vector的push_back操作后,原始元素的地址可能会改变。原因是std::vector在内存不足时会重新分配内存,导致元素地址变化。不同编译器如VS2015和g++采用不同的扩容策略,例如1.5倍或2倍扩容。因此,在使用std::vector时,需要注意对元素地址的处理,确保其有效性。

564

被折叠的 条评论
为什么被折叠?



