类的friend函数(友元函数)在类的作用域外定义,却具有访问类的非public (以及public)成员的权限。
单独的函数、整个类或其他类的成员函数都可以被声明为另一个类的友元。
friend 的声明
在类定义中函数原型前加保留字friend, 就将该函数声明为该类的友元。
若要将整个类Classtwo 的所有成员函数声明为Classone类的友元,需在Classone定义中加入如下的声明:
friend class ClassTwo;//ClassTwo的所有成员函数都是Classone的友元函数
友元函数机械化例子:
#include<iostream>
using namespace std;
class fri1
{
friend void setX(fri1 &, int);
/*友元函数声明,setX是类fril的友元函数
友元函数的声明可以出现在类的任何地方
private、protected、public这些成员访问说明符标志与友元
的声明无关,因此友元函数的声明可以出现在类的任何地方*/
public:
fri1():x(0)
{
}
void printt() const
{
cout<<"fri1里的 x: "<<x<<endl;
}
private:
int x;
};
void setX(fri1 &f, int val)
{//友元函数的定义
f.x = val;//修改private数据
//f.printt();//还可以访问成员函数
}
int main()
{
fri1 friend1;
cout<<"创建fri1对象friend1, x的值为: ";
friend1.printt();
cout<<endl;
setX(friend1, 8);
cout<<"使用友元函数setX后,x的值为: ";
friend1.printt();
return 0;
}
运行结果:
注意 友元关系是授予而不是索取。也就是,若B是A的友元,则A必须显式地声明B是它的友元。另外友元关系既是不对称的也是不传递的。 (类A是类B的友元,类B是类C的友元,不能推断类B是类A的友元,类A是类C的友元 ) 友元不是成员函数。
友元机械化例子:
#include<iostream>
using namespace std;
class fri1
{
friend class fri2;//fri2是fri1的友元类
public:
fri1():x(0)
{
}
void printt() const
{
cout<<"fri1里的 x: "<<x<<endl;
}
private:
int x;
};
class fri2
{
public:
fri2():y(9)
{
}
void print(fri1& f1,int x) const
{
cout<<"fri2里的 y: "<<y<<endl;
f1.x = x;//修改f1中x的值
f1.printt();//访问f1的成员函数
}
private:
int y;
};
int main()
{
fri1 friend1;
cout<<"创建fri1对象friend1, x的值为: ";
friend1.printt();
cout<<endl;
fri2 friend2;
cout<<"使用friend2.print(fri1,10)后: ";
friend2.print(friend1, 10);
return 0;
}
运行结果:
值得注意的是友元函数会破坏面向对象类的封装性,如果不是一定要使用,则少用或尽量不用。
本文详细介绍了C++中友元函数的概念及其使用方法。友元函数虽然定义在类的作用域之外,但却拥有访问类中非公有成员的权限。文章通过两个具体的代码示例,展示了如何声明和定义友元函数及友元类,并讨论了友元关系的特点。
9471





