0

我有一个使用这些功能插入节点的类:

在 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 所以我有

在其他类.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()是我的吸气剂_children

4

1 回答 1

1

可能是您的 getter 按值而不是按引用返回 std::vector 吗?

吸气剂应如下所示:

std::vector<Node*>& Node::children()
{
    return _children;
}

或像这样的 const 版本:

const std::vector<Node*>& Node::children() const
{
    return _children;
}
于 2013-09-05T21:43:56.447 回答