//所有函数都在类的内部实现包括友元函数
#include <iostream>
using namespace std;
//所有函数都在类的内部实现包括友元函数
template <typename T>
class Complex
{
//友元函数在类的内部实现————>但它本身还是一个友元函数(外部函数),不是类的内部成员
friend ostream& operator<< (ostream& out, Complex<T> &c)
{
out << c.a << "+" << c.b << "i";
return out;
}
friend Complex Sub(Complex &c1, Complex &c2)
{
Complex tmp(c1.a-c2.a, c1.b-c2.b);
return tmp;
}
public:
Complex(T a = 0, T b = 0)
{
this->a = a;
this->b = b;
}
//在类内部 <T> 可写可不写
Complex operator+(Complex &c)
{
Complex tmp(a+c.a, b+c.b);
return tmp;
}
private:
T a;//实部
T b;//虚部
};
int main1()
{
Complex<int> c;
Complex<int> c1(1,2), c2(3,4);
c = c1 + c2;
cout << c << endl;
c = Sub(c1, c2);
cout << c << endl;
return 0;
}
所有函数都在类的外部实现
#include <iostream>
using namespace std;
//所有函数都在类的外部实现
// 2、普通函数作为类的友元函数:
// 2.2、类的声明
template <typename T>
class Complex;
//2.2、进行函数声明
template <typename T>
Complex<T> Sub(Complex<T> &c1, Complex<T> &c2);
template <typename T>
class Complex
{
//1、运算符重载的友元函数(不在类的内部实现),需要在函数吗和形参列表之间加<T>
friend ostream& operator<< <T>(ostream& out, Complex<T> &c);
//2.3 在函数名和形参列表之间加<T>
friend Complex<T> Sub<T>(Complex<T> &c1, Complex<T> &c2);
public:
Complex(T a = 0, T b = 0);
Complex operator+(Complex &c);
private:
T a;//实部
T b;//虚部
};
//类模板的成员函数在类的外部实现,则所有函数都要写出函数模板的形式
//在表明该函数属于哪个类的时候,要在类名后面加<T>
template <typename T>
Complex<T>::Complex(T a = 0, T b = 0)
{
this->a = a;
this->b = b;
}
//函数的返回值一定要加上 <T>,
//第一个Complex<T>是函数的返回值,第二个Complex<T>是表示函数的从属
template <typename T>
Complex<T> Complex<T>::operator+(Complex &c)
{
Complex tmp(a+c.a, b+c.b);
return tmp;
}
template <typename T>
ostream& operator<<(ostream& out, Complex<T> &c)
{
out << c.a << "+" << c.b << "i";
return out;
}
template <typename T>
Complex<T> Sub(Complex<T> &c1, Complex<T> &c2)
{
Complex<T> tmp(c1.a-c2.a, c1.b-c2.b);
return tmp;
}
int main()
{
Complex<int> c;
Complex<int> c1(1,2), c2(3,4);
c = Sub<int>(c1, c2);
cout << c << endl;
return 0;
}
注意:当类模板函数说明和类模板函数实现分别在一个头文件和一个源文件里时,
如果在main.cpp文件里调用该类的时候,需要包含.cpp文件(也可以写出.hpp文件)