2

我正在编写一个使用成员变量指针作为迭代器的成员函数。但是,为了便于阅读,我想在函数中引用指针。像这样:

/* getNext will return a pos object each time it is called for each node
 * in the tree. If all nodes have been returned it will return a Pos
 * object (-1, -1).
 * TODO: Add a lock boolean to tree structure and assert unlocked for
 *       push/pop.
 */
Pos BTree::getNext () const
{
    BTreeNode*& it = this->getNextIter;

    while (it)
    {
        if (it->visited)
        {
            /* node has been visited already, visit an unvisited right
             * child node, or move up the tree
             */
            if (   it->child [BTREE_RIGHT] != NULL
                && !it->child [BTREE_RIGHT]->visited)
            {
                it = it->child [BTREE_RIGHT];
            }
            else
            {
                it = it->parent;
            }
        }
        else
        {
            /* if unvisited nodes exist on the left branch, iterate
             * to the smallest (leftmost) of them.
             */
            if (   it->child [BTREE_LEFT] != NULL
                && !it->child [BTREE_LEFT]->visited)
            {
                for (;
                     it->child [BTREE_LEFT] != NULL;
                     it = it->child [BTREE_LEFT]) {}
            }
            else
            {
                it->visited = 1;
                return it->pos;
            }
        }
    }

    it = this->root;
    this->setTreeNotVisited (this->root);
    return Pos (-1, -1);
}

这基本上就是我想要的,其中 this->getNextIter 是一个 BTreeNode*。但是我得到了错误:

    btree.cpp:238: error: invalid initialization of reference of type
'DataTypes::BTreeNode*&' from expression of type 'DataTypes::BTreeNode* const'

这种事情的适当语法是什么?

干杯,

里斯

4

1 回答 1

3

您的成员函数是const- 限定的,因此您不能修改成员变量getNextIter。您需要使用 const 引用:

BTreeNode * const & it = getNextIter;

但是,在您的函数中,您修改了it,因此您可能需要const从成员函数中删除 -qualification 或创建getNextIter成员变量mutable

当您有一个const-qualified 成员函数时,所有非mutable成员变量const在成员函数内部都是 -qualified,因此编译器为什么会报告当您尝试使用getNextIterinside of 时getNext(),它的类型为DataTypes::BTreeNode* const(注意const)。

于 2010-09-07T04:56:30.857 回答