Templates基础

  • Post author:
  • Post category:其他

一、Function Template (函数模板)

1.编译器推导模板参数、显示实例化模板参数(也可半显示半推导,从到后)
2.重载函数模板

二、Class Template(类型模板)

1.特化
2.偏特化 (某个宣告式与多个偏特化产生同等的匹配程度,则歧义)
3.预设模板参数

三、Nontype Template Parameters(非类型模板参数)

1.非类型类型模板参数
2.非类型函数模板参数
不能把浮点数、class-type物件、内部连接物件(string、字符常量)作为非类型模板参数

四、高阶基本技术

1.typedef typename _Val_types::pointer pointer;
2.this->(不理解)
3.Member Function Templates(成员函数模板)

//示例:
		template <typename T,typename CONT = std::deque<T>>
		class Stack{
		private:
		CONT elemes;
		public:
			template<typename T2>
			Stack<T>& operator= (Stack<T2> const&);
		};

4.Template Template Parameters(双重模板参数)

//示例:
		template <typename T,
			typename <typename ElEM,
					typename ALLOC = std::allocate<ElEM> >
					class CONT = std::deque>
		class Stack{
		private:
		CONT<T> elemes;
		public:
			T top()const;
		};

5.零值初始化(int、double、pointer等无构造函数的基本类型)

T X();

6.模板不支持分离编译
不同模块可能实例化出多个相同版本
失去分离编译+链接的优势
编译时间更长

7.export关键字可使模板的使用和定义分隔在不同编译单元
适用于函数模板、成员函数模板、类模板的成员函数和静态函数
不可以和inline同时使用
但使用处所有的实例化都要重新编译,兼容性可能不好,还是推荐内置式编程

8.防止Templates出错

class thread
{
	template<class _Fn,
	class... _Args,
	class = typename enable_if<
		!is_same<typename decay<_Fn>::type, thread>::value>::type>
	explicit thread(_Fn&& _Fx, _Args&&... _Ax)
	{}
}

五、基本术语

函数模板、类模板、具现化(隐式、显示)、特化(全特化、偏特化)
全特化的实作不必与泛化定义有任何关系

六、基础技术更深入

1.Member Function Templates不可以是虚函数,Class Template Member可以是虚函数
整个代码编译完成才知道有多少个成员函数模板被实例化,单个成员函数模板被实例化多少种,而虚函数表是固定的
2.Function Template和Class Template导出dll时,需要全特化版模板类型

有错误或不足欢迎评论指出!创作不易,转载请注明出处。如有帮助,记得点赞关注哦(⊙o⊙)
更多内容请关注个人博客:https://blog.csdn.net/qq_43148810


版权声明:本文为qq_43148810原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接和本声明。