迭代时删除
嗨, 我写了这个,但运行时遇到一些错误
for (vector< vector<Point> >::iterator track = tracks_.begin(); track != tracks_.end(); track++) {
if (track->empty()) { // if track is empty, remove it
tracks_.erase(track);
track++; // is this ok?
}else { //if there are points, deque
track->erase(track->begin()); //my program crashes here after a while... ;(
}
}
我有一个由点向量组成的向量(2个整数),我将其称为轨道(1个轨道是1个点向量) 我想检查每个轨道,如果它们包含点,则删除第一个轨道,否则删除轨道。这是正确的吗?
提前致谢。
Possible Duplicates:
Vector.erase(Iterator) causes bad memory access
iterate vector, remove certain items as I go.
Hi,
I wrote this but I am get some errors when running it
for (vector< vector<Point> >::iterator track = tracks_.begin(); track != tracks_.end(); track++) {
if (track->empty()) { // if track is empty, remove it
tracks_.erase(track);
track++; // is this ok?
}else { //if there are points, deque
track->erase(track->begin()); //my program crashes here after a while... ;(
}
}
I have a vector of vector of points (2 ints) whose I call tracks (1 track is 1 vector of points)
I want to check each track and if they contain points then delete the first one otherwise delete the track. Is this correct?
Thanks in advance.
如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。
绑定邮箱获取回复消息
由于您还没有绑定你的真实邮箱,如果其他用户或者作者回复了您的评论,将不能在第一时间通知您!
发布评论
评论(2)
向量的
erase()
使现有迭代器无效,但它返回 一个新的迭代器,指向被删除的元素之后的元素。返回的迭代器可用于继续迭代向量。你的循环可以这样写:
A vector's
erase()
invalidates existing iterators, but it returns a new iterator pointing to the element after the one that was removed. This returned iterator can be used to continue iterating over the vector.Your loop could be written like this:
我不确定您遇到了什么错误,但很可能您正在使迭代器无效。
您应该阅读 http://www.angelikalanger.com/Conferences/Slides/ CppInvalidIterators-DevConnections-2002.pdf
具体来说,
vector::erase
使所有迭代器以及对位置或第一个元素之后的元素的引用无效。I'm not sure what errors you're getting, but chances are that you're invalidating your iterator.
You should read http://www.angelikalanger.com/Conferences/Slides/CppInvalidIterators-DevConnections-2002.pdf
Specifically,
vector::erase
invalidates all iterator and references to elements after position or first.