今天碰到一个问题:
vector<int> a;
a.push_back(0);
int* b = &a[0];
for (int i = 0; i <100; ++i) {
a.push_back(50);
}
结果:*b != a[0]
纠结了好久,原来是vector的push_back 方法有时(不够用)时重新分配内存(在栈上),地址会变化,
可以一开始用reserver预先分配足够大的空间。
以前就知道这个问题,但是具体用起来还是忘记,fuck
今天碰到一个问题:
vector<int> a;
a.push_back(0);
int* b = &a[0];
for (int i = 0; i <100; ++i) {
a.push_back(50);
}
结果:*b != a[0]
纠结了好久,原来是vector的push_back 方法有时(不够用)时重新分配内存(在栈上),地址会变化,
可以一开始用reserver预先分配足够大的空间。
以前就知道这个问题,但是具体用起来还是忘记,fuck