你儿时的心愿, 现在的理想, 这些都是你要追逐的东西, 你可要放弃很多,
但唯独不能放弃自己的理想, 因为理想代表的就是你自己.
看一个人能否做自己, 就看他是否坚持了自己的理想, 坚持了多久.
如果你现在有梦, 请你一定要去追.
7. 模板初阶
7.1 泛型编程7.1.1 定义编写与类型无关的通用代码,是代码复用的一种手段,模板是泛型编程的基础。7.1.2 模板的分类函数模板类模板7.1.3 模板编译的两个阶段(1)实例化前--只读模板进行简单语法检测;(2)实例化后--编译器就会根据T的实际类型来生成代码。
7.2 函数模板7.2.1 定义函数模板代表了一个函数家族&#xff0c;该函数模板与类型无关&#xff0c;在使用时被参数化&#xff0c;根据实参类型产生函数的特定 类型版本。7.2.2 格式template<typename T1, typename T2,......,typename Tn> 返回值类型 函数名(参数列表){} 尖括号中先写关键字typename&#xff08;或class&#xff09;&#xff0c;后面跟一个类型参数T&#xff0c;这个类型参数实际上是一个虚拟的类型名&#xff0c;表示模板中出现的T是一个类型名&#xff0c;但是现在并未指定它是哪一种具体的类型&#xff1b;注意&#xff1a;typename是用来定义模板参数关键字&#xff0c;也可以使用class(切记&#xff1a;不能使用struct代替class)&#xff0c;建议使用typename。7.2.3 原理&#xff08;1&#xff09;模板是一个蓝图&#xff0c;它本身并不是函数&#xff0c;是编译器用使用方式产生特定具体类型函数的模具。所以其实模板就 是将本来应该我们做的重复的事情交给了编译。&#xff08;2&#xff09;在编译阶段&#xff0c;编译器需要对实参的类型进行推演&#xff0c;来确认模板参数的列表中T的实际类型&#xff0c;最后生成处理具体类型的有效代码。7.2.4 函数模板的实例化&#xff08;用不同类型的参数使用函数模板时&#xff0c;称为函数模板的实例化&#xff09;隐式实例化让编译器根据实参推演模板参数的实际类型&#xff1b;显式实例化在函数名后的<>中指定模板参数的实际类型&#xff1b;7.2.5 模板参数的匹配原则一个非模板函数可以和一个同名的函数模板同时存在&#xff0c;而且该函数模板还可以被是被实例化为这个非模板函数&#xff1b;对于非模板函数和同名函数模板&#xff0c;如果其他条件都相同&#xff0c;在调动时会优先调用非模板函数而不会从该模板产生出一个实例&#xff0c;如果模板可以产生一个具有更好匹配的函数&#xff0c;那么将选择模板&#xff1b;模板函数不允许自动类型转换&#xff0c;但普通函数可以进行自动类型转换&#xff1b;
7.3 类模板&#xff08;1&#xff09;类模板的定义格式template<typename T1,typename T2...typename T1,typename Tn>class 类模板名{}&#xff08;2&#xff09;类模板的实例化类模板实例化与函数模板实例化不同&#xff0c;类模板实例化需要在类模板名字后跟<>,然后将实例化的类型放在<>中即可&#xff0c;类模板名字不是真正的类&#xff0c;而实例化的结果才是真正的类&#xff1b;