我们可以分享自己的秘密给信得过的朋友。
类中的私有成员就是自己的秘密,当其它函数或类被friend修饰,那么它就可以访问类中的私有成员。
#include<iostream>
#include<string>
using namespace std;
// 通过全局函数 打印person的信息
template<class T1,class T2>
class Person
{
public:
Person(T1 name,T2 age)
{
this->m_Name = name;
this->m_Age = age;
}
void printPerson(Person<T1,T2> p)
{
cout<<"姓名: "<<p.m_Name<<" 年龄: "<<p.m_Age<<endl;
}
private:
T1 m_Name;
T2 m_Age;
};
// 全局函数
void test01()
{
Person<string,int>p("Tom",20);
printPerson(p);
}
int main()
{
test01();
return 0;
}
运行上面的代码,printPerson里面是输出类中的私有成员的值,它没有被friend修饰,编译代码直接报错:
friend void printPerson(Person<T1,T2> p)
{
cout<<"姓名: "<<p.m_Name<<" 年龄: "<<p.m_Age<<endl;
}
成功输出类中私有成员的值:
#include<iostream>
#include<string>
using namespace std;
//首先告诉编译器模板类
template<class T1,class T2>
class Person;
//类外实现
template<class T1,class T2>
void printPerson2(Person<T1,T2> p)
{
cout<<"类外实现 --- 姓名: "<<p.m_Name<<" 年龄: "<<p.m_Age<<endl;
}
template<class T1,class T2>
class Person
{
public:
Person(T1 name,T2 age)
{
this->m_Name = name;
this->m_Age = age;
}
//类外实现,如果全局函数是类外实现,1.要加空模板参数列表 2.需要让编译器提前知道这个函数的存在,因为它是模板,不是普通函数。
friend void printPerson2<>(Person<T1,T2> p);
private:
T1 m_Name;
T2 m_Age;
};
void test02()
{
Person<string,int>p("Jerry",20);
printPerson2(p);
}
int main()
{
test02();
return 0;
}