我有一个插入带有这些函数的节点的类:
在Node.h中
class Node
{
public:
...
void insertChild(Node *child);
vector<Node *> children();
vector<Node *> _children;
};
在Node.cpp中
void Node::insertChild(Node *child){
_children.push_back(child);
}
vector<Node *> Node::children(){
return _children;
}
在Trie.h中
class Trie
{
public:
Node *getRoot() const;
Node *root;
void addWord(string prefix);
}
在Trie.cpp中
Trie::Trie()
{
root = new Node();
}
Node *Trie::getRoot() const
{
return root;
}
void Trie::addWord(string prefix){
Node *current = root;
if(prefix.length() == 0)
{
current->setTypeMarker(DAT_NODE);
return;
}
for(int i = 0; i < prefix.length(); i++){
Node *child = current->lookupChild(prefix[i]);
if(child != NULL)
{
current = child;
}
else
{
Node *tmp = new Node();
tmp->setContent(prefix[i]);
current->insertChild(tmp);
current = tmp;
}
if(i == prefix.length()-1)
current->setTypeMarker(DAT_NODE);
}
}
在另一个课程中,我想迭代_children,所以我有
在OtherClass.h中
class OtherClass
{
public:
Trie *trie;
void addWords(string word)
void someFunction()
}
在OtherClass.cpp中
OtherClass::OtherClass()
{
tree = new Trie();
}
void OtherClass::addWords(string word)
{
tree->addWord(word);
}
void OtherClass::someFunction()
{
Node *root = tree->getRoot();
for(std::vector<Node *>::iterator it = root->children().begin(); it != root->children().end(); it++) {
Node * test = *it;
}
}
然而,当我运行它时,测试是零。我可以查看root并看到子节点包含我的节点,但是为什么我不能在向量迭代器中取消引用它们? children()
是_children
答案 0 :(得分:1)
可能是你的getter返回std :: vector的值而不是引用?
getter应如下所示:
std::vector<Node*>& Node::children()
{
return _children;
}
或者像这样的const版本:
const std::vector<Node*>& Node::children() const
{
return _children;
}