c++类模板和友元函数的特殊情况
我会将类模板的成员函数和友元函数做对比
一 、普通类模板
创建一个Demo类模板:
这是一个普通类模板,里面的T是虚拟的类型参数。在每一个类模板的成员函数实现之前要加模板声明,成员函数返回值、域名、函数参数是类名的情况下要在旁加<虚拟类型参数>,成员函数要定义一个类模板对象时类名旁可以不加<虚拟类型参数>,一般实际开发中是文件分离的,这里仅为演示效果这里提一下不要包含类模板的头文件,会报错,要包含它的cpp文件,建议把cpp文件改为hpp文件 ,这是c++不成文的规定,hpp代表这是类模板。
在使用时类模板时应:
类模板类名加<>里面加实际类型
二、类模板的友元函数:
template
class Demo {
template //友元函数在类模板的声明
friend Demo& addK(Demo& d1, Demo& d2);
public:
Demo(T k);
T getK();
Demo &operator+( Demo& d);
void print();
private:
T k;
};
template
Demo::Demo(T k) {
this->k = k;
}
template
T Demo::getK() {
return k;
}
template
Demo &Demo::operator+(Demo& d) {
Demo tmp(0);
tmp.k = this->k + d.k;
return tmp;
}
template
void Demo::print() {
cout << k << endl;
}
//友元函数的实现
template
Demo& addK(Demo& d1, Demo& d2) {
Demo tmp(0);
tmp.k = d1.k + d2.k;
return tmp;
}
int main(void) {
Demo d(30);
Demo d1(40);
Demo tmp(0);
tmp = addK(d, d1);
cout << tmp.getK();
return 0;
}
类模板的友元函数错一步就无法通过编译,而且报错千奇百怪,我老师说的。 在友元函数的声明前加模板声明,你可以理解为友元函数的声明是在类模板外面的和在类模板外面的成员函数实现相同,而且在友元函数内部需要定义个类模板的对象时必须在类名旁加<虚拟类型参数>,
三、结尾
第三篇了 ,希望能帮助到人,我挺自豪的,加油!坚持,高兴!