有什么方法可以检查迭代器(无论它来自 vector 、列表、双端队列...)是否(仍然)可取消引用,即尚未失效?
我一直在使用try
-catch
,但是有没有更直接的方法呢?
示例:(不起作用)
list<int> l;
for (i = 1; i<10; i++) {
l.push_back(i * 10);
}
itd = l.begin();
itd++;
if (something) {
l.erase(itd);
}
/* now, in other place.. check if it points to somewhere meaningful */
if (itd != l.end())
{
// blablabla
}
最佳答案
我假设您的意思是“是一个有效的迭代器”,它没有因容器的更改而失效(例如,插入/删除到 vector/从 vector 中删除)。在这种情况下,不,您无法确定迭代器是否(安全地)可解引用。
关于c++ - 检查迭代器是否有效,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/2062956/