在C ++中从vector向量取消引用对象的指针

时间:2013-09-05 21:16:56

标签: c++ pointers vector

我有一个插入带有这些函数的节点的类:

在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

的吸气者

1 个答案:

答案 0 :(得分:1)

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

getter应如下所示:

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

或者像这样的const版本:

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