我找不到程序引发SIGBART错误的原因。

调用此函数时,我已经缩小了范围。

bool Node::isEdgeConnected(Node vertex1, Node vertex2){

//I'm not sure if this is the right way to copy this vector <list>
vector<list<Node> > myEdgeList = *edgeList;//edgeList is a private data member of Node

vector<list<Node> >::iterator it;
cout << myEdgeList.size();


for (it = myEdgeList.begin(); it != myEdgeList.end(); it++) {
    list<Node> edge;
    edge = *it;
    Node placeNode = edge.front();

    cout <<placeNode.getNodeId()<<endl;
    list<Node>::iterator eIt;
    for (eIt = edge.begin(); eIt != edge.end(); eIt++) {
        Node placeNode1, placeNode2;
        placeNode1 = edge.front();
        placeNode2 = *eIt;

        cout << placeNode1.getNodeId() << " " << placeNode2.getNodeId()<<endl;
        if(placeNode1.getNodeId() == vertex1.getNodeId() &&
           placeNode2.getNodeId() == vertex2.getNodeId()){
            return true;
        }
    }
}
return false;

}


任何帮助,将不胜感激。

最佳答案

您的代码很可能在Node placeNode = edge.front();行中失败,您需要检查edge是否为空

if (edge.empty()){
   continue;
}
Node placeNode = edge.front();


顺便说一句,isEdgeConnected()函数仅用于检查edgeList中的节点值,您不需要复制所有元素。如果您的edgeList很大,那么复制将很昂贵。

例如,您可以直接迭代edgeList,而且++iter比`iter ++更有效,请参见this

for (vector<list<Node> >::iterator it = edgeList->begin();
     it != edgeList->end(); ++it) {
}

10-06 07:08