Wil*_*iam 3 c++ crash sdl vector
有谁能告诉我
为什么这会导致我的程序崩溃?假设它使得它使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
Run Code Online (Sandbox Code Playgroud)
您的迭代器it
不能保证有效,之后order->push_back(k);
可以重新分配向量中的元素.由于我没有看到你实际上it
在任何地方递增,我建议order->begin()
在这个函数中更换它的丑陋的解决方案.
归档时间: |
|
查看次数: |
975 次 |
最近记录: |