为什么友元函数不能访问类的私有变量?

问题描述

#include <iostream>
using namespace std;
class base_A {
int a = 5,b = 6;
friend void derive::print(base_A);
};
class derive {
public:
    void print(base_A obj) {
        cout << obj.a << " " << obj.b;
    }
};
int main() {
    base_A obj1;
    derive obj2;
    obj2.print(obj1);
}

虽然我使用了朋友关键字,但我无法访问私有变量。任何人都请帮助我。

解决方法

您需要正确地在程序中放置彼此相关的声明。否则编译器将发出一个错误,即名称未声明或类型不完整。例如

#include <iostream>
using namespace std;

class base_A;

class derive {
public:
    void print(base_A obj);
};

class base_A {
int a = 5,b = 6;
friend void derive::print(base_A);
};

void derive::print(base_A obj) {
    cout << obj.a << " " << obj.b;
}

int main() {
    base_A obj1;
    derive obj2;
    obj2.print(obj1);
}

在这种情况下,程序输出是

5 6

也就是说,因为名称 base_A 在类 derive 中被引用,那么至少名称 base_A 的声明(前向声明)应在类 {{1} 的定义之前}}。

另一方面,friend函数的定义应该知道类derive的完整定义。所以它的定义应该放在类base_A的定义之后。