当前位置: 首页 > article >正文

C++泛型编程:类模板(下)

类模板与继承:

需要指定模板参数的类型

template <class T>
class Base
{
public:
	T m;
};
class Son :public Base<int>
{
};
template <typename T1,typename T2>
class Son2 :public Base<T2>
{
public:
	Son2()
	{
		cout << "T1的类型:" << typeid(T1).name() << endl;
		cout << "T2的类型:" << typeid(T2).name() << endl;
	}
	T1 obj;
};
void test01()
{
	Son2<int, char> S2;
}

类模板分文件编写:

方法1:(主流)

将声明与实现放在同一个文件中,可将该文件的后缀名由 “.h" 改为 ".hpp" 。并非强制,而是方便其他用户阅读源文件。

方法2:

头文件    "person.h":

#pragma once
#include<iostream>
#include<string>
using namespace std;
template <class T1,class T2>
class Person
{
public:
	Person(T1 name, T2 age);
	void showPerson();
	T1 m_Name;
	T2 m_Age;
};

源文件   "person.cpp":

#include"person.h"
template <class T1,class T2>
Person<T1, T2>::Person(T1 name, T2 age)
{
	this->m_Name = name;
	this->m_Age = age;
}
template <class T1, class T2>
void Person<T1, T2>::showPerson()
{
	cout << this->m_Name << " " << this->m_Age << endl;
}

在主函数中包含源文件,(原因:模板的函数在调用时才会创建)这样使得编译器可以看到函数的具体实现。

#include<iostream>
using namespace std;
#include"person.cpp"
void test02()
{
	Person<string, int> p1("Zhang", 19);
	p1.showPerson();
}
int main()
{
	test02();
	system("pause");
	return 0;
}

类模板与友元:

全局函数类内实现:

直接在类内声明友元即可

template <class T1, class T2>
class Person
{
	friend void printPerson(Person<T1, T2> p)
	{
		cout << p.m_Name << " " << p.m_Age << endl;
	}
public:
	Person(T1 name, T2 age)
	{
		this->m_Name = name;
		this->m_Age = age;
	}
	T1 m_Name;
	T2 m_Age;
};
全局函数类外实现:

需要让编译器提前知道函数的存在

同时类内的函数声明需要加空模板参数列表

template<typename T1, typename T2>
class Person;
template<typename T1, typename T2>
void printPerson2(Person<T1, T2> p)
{
	cout << "Name:" << p.m_Name << " Age:" << p.m_Age << endl;
}
template <class T1, class T2>
class Person
{
	//需要加空模板参数列表
	friend void printPerson2<>(Person<T1, T2> p);
public:
	Person(T1 name, T2 age)
	{
		this->m_Name = name;
		this->m_Age = age;
	}
	T1 m_Name;
	T2 m_Age;
};

void test03()
{
	Person<string, int> p("Tom", 19);
	printPerson(p);
	printPerson2(p);
}

建议:没有特殊需求的话,全局函数做类内实现,用法简单而且编译器可以直接识别


http://www.kler.cn/a/229052.html

相关文章:

  • 设计一个流程来生成测试模型安全性的问题以及验证模型是否安全
  • 017:推理框架为什么可以加速AI推理?
  • vue3学习三
  • 关于AWS网络架构的思考
  • css盒子水平垂直居中
  • 大疆发布可折叠航拍无人机,仅重249g,支持 4800 万像素拍摄
  • 【Iceberg学习一】什么是Iceberg?
  • 飞天使-k8s知识点12-kubernetes散装知识点1-架构有状态资源对象分类
  • PostgreSQL解决序列(自增id)自动增长冲突
  • 电路设计(10)——超温报警电路的proteus仿真
  • Windows10安装VScode + mingw64 + GSL
  • 【C++搜索二叉树】
  • HuggingFace库中BERTForxxx模型代码详细分析 使用BERT进行无监督预训练
  • 第97讲:MHA高可用集群模拟主库故障以及修复过程
  • Java大致面试题及答案,文档格式为md格式
  • 【计算机二级考试C语言】C排序算法
  • 各种编程语言送祝福:2024龙年大吉
  • sqli.labs靶场(54-65关)
  • 适用于 Windows 和 Mac 的 16 款最佳数据恢复软件
  • 软件漏洞概念与原理
  • Zookeeper相关面试准备问题
  • 改变终端安全的革命性新兴技术:自动移动目标防御技术AMTD
  • 【自定义序列化器】⭐️通过继承JsonSerializer和实现WebMvcConfigurer类完成自定义序列化
  • oracle视图二次查询慢
  • C++类与对象(下)
  • 第十二讲_JavaScript浏览器对象模型BOM