任何人都可以告诉我
为什么这会导致我的程序崩溃?假设使它顺序使t矢量中的所有元素都位于(y + height)。
编辑:在包含“插入”的行上崩溃。
void createDrawOrder(vector<Thing*> t, vector<int> *order) {
int min = t[0]->y + t[0]->height;
int max = t[0]->y + t[0]->height;
vector<int>::iterator it;
it = order->begin();
order->push_back(0);
for (int i = 1; i < (int) t.size(); i++) {
if ((t[i]->y + t[i]->height) < min) {
min = (t[i]->y + t[i]->height);
order->insert(it, i);
}
else if((t[i]->y + t[i]->height) >= min && (t[i]->y + t[i]->height) < max){
int tempsize = (int) order->size();
for (int j = 0; j < tempsize; j++){
if((t[i]->y + t[i]->height) <= (t[(*order)[j]]->y + t[(*order)[j]]->height)){
order->insert(it + j, i);
}
}
}
else if ((t[i]->y + t[i]->height) >= max) {
max = (t[i]->y + t[i]->height);
order->push_back(i);
}
}
}//end method max
答案 0 :(得分:8)
在it
之后,您的迭代器order->push_back(k);
无法保证有效,它可以重新分配向量中的元素。由于我没有看到你实际上在任何地方递增it
,我建议在这个函数中用order->begin()
替换它的更丑陋的解决方案。