访问没有对象的私有成员变量

Accessing a private member variable without object

本文关键字:成员 变量 对象 访问      更新时间:2023-10-16
class BinarySearchTree
{
private:
Node *root;
public:
BinarySearchTree() ;
~BinarySearchTree();
void insert_node(int, Node*);
void print_tree(Node *);
friend Node* get_root();
};
/**********************BinarySearchTree definition***************/
BinarySearchTree::BinarySearchTree() : root(nullptr)
{
}
Node* get_root()
{
Node* x= root;
return x;
}

编译器说error C2065: 'root' : undeclared identifier为什么编译器无法识别root尽管get_root是友元函数?

同样,为什么我不能使用这样的默认参数?

void BinarySearchTree::insert_node(int inserted_key,Node* traverse_ptr = root);

对于你关于get_root的问题,编译器足够聪明,可以确定get_rootBinarySearchTree的朋友。这不是这里的问题。相反,当编译器看到这一行时,它不知道你要求它从哪个BinarySearchTree对象读取根:

Node* x = root;

可以这样想 - friend 函数是一个自由函数,就像任何其他自由函数一样,除了它可以读取私有字段。但是,为了读取BinarySearchTree对象的私有字段,它需要一个实际的、诚实善良的BinarySearchTree对象来读取该字段。

这不会提供成员函数,因为成员函数相对于某个接收器对象隐式操作。在BinarySearchTree的成员函数中,如果你谈论root,C++把它解释为"this对象的root域"。

鉴于您在这里尝试做的事情,我认为您应该只get_root成员函数而不是友元函数。您还可以更改get_root,使其采用 BST 作为输入:

Node* get_root(const BinarySearchTree& bst)
{
return bst.root;
}

你问了一个单独的问题,为什么你不能给出这样的默认参数:

void BinarySearchTree ::insert_node(int inserted_key, Node* traverse_ptr = root);

C++规范只是简单地不允许您使用成员变量作为成员函数的默认值。我相信这与实现问题有关,如果您使用多重继承,则指向对象的指针可能指向对象的中间,并且无法静态地知道对该字段的偏移量。

但是,您可以通过执行以下操作来解决此问题:

class BinarySearchTree {
public:
void insert_node(int inserted_key);
void insert_node(int inserted_key, Node* traverse_ptr);
}
void BinarySearchTree::insert_node(int inserted_key) {
insert_node(inserted_key, root);
}
void BinarySearchTree::insert_node(int inserted_key, Node* traverse_ptr) {
...
}

这使用重载而不是默认参数,并或多或少地完成相同的事情。