类的友元函数是定义在类外部,但有权访问类的所有私有成员和保护成员。尽管友元函数的原型有在类的定义中出现过,但友元函数并不是成员函数。
友元可以是一个函数,该函数被称为友元函数;友元也可以是一个类,该类被称为友元类。在这种情况下,整个类及其所有成员都是友元。如果要声明函数为一个类的友元,需要在类定义中该函数原型前使用关键字friend,如下所示:
class Box { double width; public: double length; friend void printWidth(Box box); void setWidth(double wid); };
声明类ClassTwo的所有成员函数作为类的ClassOne的友元,需要在类ClassOne的定义中放置如下声明:
friend class ClassTwo;
/*** friend.cpp ***/ #include<iostream> using namespace std; class Box { double width; public: friend void printWidth(Box box); void setWidth(double wid); }; void Box::setWidth(double wid) { width = wid; } void printWidth(Box box) { cout << "Width of box : " << box.width << endl; } int main() { Box box; box.setWidth(10.0); printWidth(box); return 0; }
运行结果:
exbot@ubuntu:~/wangqinghe/C++/20190807$ ./friend
Width of box : 10
因为友元函数没有this指针,则参数要有三种情况:
- 要访问非static成员时,需要对象作为参数;
- 要访问static成员或者全局变量时,不需要对象作为参数;
- 如果做参数的对象是全局对象,则不需要对象做参数。
友元类的使用
/*** classfriend.cpp ***/ #include<iostream> using namespace std; class Box { double width; public: friend void printWidth(Box box); friend class BigBox; void setWidth(double wid); }; class BigBox { public: void Print(int width, Box &box) { box.setWidth(width); cout << "Width of box: " << box.width << endl; } }; void Box::setWidth(double wid) { width = wid; } void printWidth(Box box) { cout << "Width of box : " << box.width << endl; } int main() { Box box; BigBox big; box.setWidth(10.0); printWidth(box); big.Print(20,box); return 0; }
运行结果:
exbot@ubuntu:~/wangqinghe/C++/20190807$ ./classfriend
Width of box : 10
Width of box: 20