-2

我不断收到此错误。我知道是什么功能导致它,但不知道如何修复它。从这个帖子在线查找说:

您需要将指针传递给动态分配的对象,或者在您的 chainLink 类中创建自己的 insde。

但是,当我尝试传递一个字符串指针时。错误仍然弹出。这是我的代码。

#include <iostream>
#include "MWTNode.h"
#include "MWT.h"
using namespace std;

int main() {
MWT t;
string str ="abc";
string* strPtr = &str;
t.insert(strPtr);
std::cout << "Hello, World!" << std::endl;
return 0;
}


#include "MWTNode.h"
class MWT {
public:
MWTNode *root;
string find(const string &);
void insert(const string* string);

};
void MWT::insert(const string* word) {
MWTNode* curr = root;
MWTNode newNode;
string w = *word;
for (int i = 0; i < word->length(); i++) {
    const char c = w[i];
    if (curr->children.find(c) == curr->children.end()){

        //curr->children[c]= MWTNode();
        //node->frequency=node->frequency+1;
    }
    curr = &(curr->children[c]);
}
curr->flag = true;
}



#include <unordered_map>
#include <vector>
#include <string>
#include <sstream>
#include <set>
using namespace std;

class MWTNode {
public:
unordered_map<char, MWTNode> children;
string value;
bool flag;
int frequency;

MWTNode(const string &);
MWTNode(const char c);
MWTNode();
void setFrequency ();
int getFrequency ();

};


MWTNode::MWTNode(const string &val) {
value = val;
flag = false;
frequency = 0;
}

MWTNode::MWTNode(const char c) {
value =c;
flag = false;
frequency = 0;
}

MWTNode::MWTNode() {
value ="";
flag = false;
frequency = 0;
}
4

1 回答 1

1

让我们突出显示您显示的几行代码

class MWT {
public:
MWTNode *root;
// ...
};

在那里,您将成员变量声明root为指针。

void MWT::insert(const string* word) {
MWTNode* curr = root;
// ...
}

在上面你指出指向curr的地方root

你从来没有在root任何地方说明问题!该MWT::root变量未初始化,将具有不确定的值。在没有初始化的情况下以任何方式使用此指针将导致未定义的行为

是的,你使用这个指针,因为你在函数curr内部取消引用。MWT::insert

有点不清楚你在做什么(对我来说),但在尝试取消引用它之前,你需要确保root(因此)是一个有效的指针。curr

于 2018-02-19T07:12:51.990 回答