一:让函数模板的某个实例成为友元函数
#include <iostream>
#include <vector>
using namespace std;
#pragma warning(disable : 4996)
template <typename T> void func(); //声明不可少
class A
{
friend void func<int>();
private:
void fun()
{
cout << "A::fun" << endl;
}
};
template <typename T>
void func()
{
A obj;
obj.fun();
}
int main()
{
func<int>();
//func<float>(); 错误,没有针对float实例化的友元
return 0;
}
二:友元模板
#include <iostream>
#include <vector>
using namespace std;
#pragma warning(disable : 4996)
class A
{
template <typename T>
friend void func();
private:
void fun()
{
cout << "A::fun" << endl;
}
};
template <typename T>
void func()
{
A obj;
obj.fun();
}
int main()
{
func<int>();
func<float>();
return 0;
}
三:在类模板当中定义友元函数
#include <iostream>
#include <vector>
using namespace std;
#pragma warning(disable : 4996)
template <typename T>
class A
{
//调用的时候才会被实例化出来,如果func这个函数里面比较简单,那么这个函数会被当做内联函数处理
friend void func(A<int>& mya) //这么做一般是因为在这个函数当中需要调用类A的私有成员函数或者私有变量
{
mya.fun();
}
private:
void fun()
{
cout << "A::fun" << endl;
}
};
int main()
{
A<int> obj;
func(obj); //当作全局函数调用即可,如果类A在某个命名空间中。调用的时候不需要加命名空间修饰符
return 0;
}