运算符重载导致分段错误

Segmentation fault with operator overloading

本文关键字:分段 错误 重载 运算符      更新时间:2023-10-16

我正在创建一个二进制树程序,我想重载一些运算符。我已经尝试重载+运算符,这样当我编写类似myTree + 5的内容时,它会在树上添加5作为节点。

这是我的代码:

BST myTree;
void operator+(BST left, int right) {
    myTree.addLeaf(right);  
}
int main() {    
    vector<int> treeKeyList;
    srand((unsigned)time(NULL));
    int before = rand() % 20 + 1;  
    for (int i = 0; i < before; i++) {
        int after = rand() % 20 + 1;
        treeKeyList.push_back(after);
        cout << treeKeyList[i] << " ";
    }
    cout << endl;
    for (int i = 0; i < treeKeyList.size(); i++) {
        myTree + treeKeyList[i];
    }
}

目前,它似乎在一个循环中运行良好,但当它试图添加带有分段错误的第二个值时,它会崩溃。我认为问题一定出在我显示的代码中,因为在我添加重载之前,它工作得很好。如果我改为这样做:

for (int i = 0; i < treeKeyList.size(); i++) {
    myTree.addLeaf(treeKeyList[i]);
}

它工作得非常好。有什么想法吗?

很可能需要将BST作为参考。也可以考虑使用+=而不是+