访问迭代器值会导致segfault 11
Accessing iterator value causes segfault 11
我有一个循环,可在邻接列表中删除图形边缘。看起来这样:
void Graph::removeEdge(int a, int b)
{
vector<int>::iterator it = adjList[a].begin();
while(*it != b) it++;
adjList[a].erase(it);
it = adjList[b].begin();
while(*it != a) it++;
adjList[b].erase(it);
}
几次尝试后,我得到了Segmentation fault: 11
错误。它是由访问*it
引起的。什么是原因,如何解决?
更多信息:
// This is my structure
vector<int> *adjList;
Graph::Graph(int V)
{
this->V = V;
adjList = new vector<int>[V];
clear();
}
这里可能发生的事情是:1.卡在无限环路中,(在您的情况下:segfault)2.擦除非现有迭代器(segfault)。
要纠正这些,请这样做:
而不是:
while(*it != b) it++;
adjList[a].erase(it);
做:
while(it != adjList[a].end() && *it != b) it++;
if (it != adjList[a].end()) adjList[a].erase(it);
如果在到达end
时未找到元素b
,则将结束循环,并且if
子句将确保您删除现有的迭代器。
相关文章:
- 使用std::multimap迭代器创建std::list
- 来自 std::list 的迭代器 .end() 按预期返回"0xcdcdcdcdcdcdcdcd"但 .begin()
- C++中带有List类的迭代器Segfault
- 如何在c++迭代器类型中包装std::chrono
- 集合上的输出迭代器:assign和increment迭代器
- Boost Spirit,获取迭代器内部语义动作
- 对于set上的循环-获取next元素迭代器
- 为什么output_editor Concept不需要output_e迭代器标记
- c++17文件系统::recursive_directory迭代器()在mac上没有给出这样的目录,但在windows上
- 使用迭代器时如何访问对象在向量中的位置?
- std::vector::迭代器是否可以合法地作为指针
- 跟随整数索引列表的自定义类迭代器
- 不明白迭代器,引用和指针失效,一个例子
- 我可以使用反向迭代器作为ForwardIt吗
- ESP8266单片机矢量迭代器的C++问题
- 迭代器:如果 '*' 返回元素的引用,为什么删除 *(myList.end()) 会给出 SegFault
- 怪异的迭代器行为+带有无序集的segfault
- 访问迭代器值会导致segfault 11
- 取消迭代器时出现Segfault
- C++-映射迭代器访问导致segfault