Template函数

1.模板函数为不同的模板实参定义了一个函数家族。它的表示看起来和普通的函数很相似,唯一的区别是有些函数元素是未确定的:这些参数将在使用的时候被参数化。

template <typename T>
inline T const& max(T const& a,T const& b)
{
    return a<b ? b : a;
}
上述例子中的参数类型没有确定,用模板参数T来代替。
 

2.函数模板的实例化:使用具体的类型代替模板参数的过程。这个过程产生了一个模板的实例。这个过程是在编译的时候进行的。

模板内部的操作要被进行参数的类型所支持,否则会出错。

在编译的时候:

1)实例化前,先检查模板代码本身,查看语法错误等,如遗漏分号等;

2)在实例化期间,检查模板代码,查看是不是所有的调用都有效。如该实例化类型不支持某些函数的调用。

3.显示指定模板参数

模板参数不支持自动类型转换,每个T都必须准确的匹配。

template <typename T>
inline T const7 max(T const& a, T cosnt& b);
...
max(4,7)                    //OK
max(4,4.2)                //ERROR,第一个是int,第二个是double
有几种解决办法,
1)max(static_cast(double)(4),4.2)   //OK
2)显示指定模板参数:
max<double>(4,4.2)
3)使用连个模板参数。
 

4.重载函数模板

和普通函数一样,模板函数同样可以被重载,相同的函数名称可以具有不同的函数定义。

几条基本的原则:

1)非模板函数和一个同名的模板函数可以同时存在。对于非模板函数和同名的函数模板,如果其他条件都相同的话,在调用的时候将调用非模板函数,不会实例化模板函数。

2)如果模板产生一个更好的匹配,选择模板参数。

3)可以显示的指定一个空的模板实例列表,告诉编译器,用模板来匹配。

4)函数的所有重载说明在该函数被调用位置之前。

时间: 2024-10-13 10:20:45

Template函数的相关文章

理解Underscore中的_.template函数

Underscore中提供了_.template函数实现模板引擎功能,它可以将JSON数据源中的数据对应的填充到提供的字符串中去,类似于服务端渲染的模板引擎.接下来看一下Underscore是如何实现模板引擎的. 工具准备 首先是_.template函数的配置项,Underscore源码中配置了默认的配置项: _.templateSettings = { // 执行JavaScript语句,并将结果插入. evaluate: /<%([\s\S]+?)%>/g, // 插入变量的值. inte

angularjs $routeProvider template 函数及参数解惑

在angularjs官方文档关于$routeProvider的配置中,对template和templateUrl的配置有这么一段话 if it is a function, it will be called with the following parameters: {Array.<Object>} - route parameters extracted from the current$location.path() by applying the current route 读起来相

template 函数模版使用

#include <iostream> #include <string> template<class T> T min(T a[], int n) { int i; T minv = a[0]; for (i = 1; i < n;i++) { if (minv>a[i]) { minv = a[i]; } } return minv; } void main() { int a[] = { 1, 4, 5, 2, 1, 5, 5 }; std::cou

C++ template —— 函数对象和回调(十四)

本篇是本系列博文最后一篇,主要讲解函数对象和回调的相关内容.函数对象(也称为仿函数)是指:可以使用函数调用语法进行调用的任何对象.在C程序设计语言中,有3种类似于函数调用语法的实体:函数.类似于函数的宏和函数指针.由于函数和宏实际上并不是对象,因此在C语言中,我们只把函数指针看成仿函数.然而在C++中,还存在其他的函数对象:对于class类型,我们可以重载函数调用运算符:还存在函数引用的概念:另外,成员函数和成员函数指针也都有自身的调用语法.本篇在于把仿函数的概念和模板所提供的编译期参数化机制结

underscore 复习 对象函数 篇章

_.partial = function(func) { var boundArgs = slice.call(arguments, 1); var bound = function() { var position = 0, length = boundArgs.length; var args = Array(length); for (var i = 0; i < length; i++) { args[i] = boundArgs[i] === _ ? arguments[positio

c语言文件操作函数

c语言文件操作函数大全 fopen(打开文件) 相关函数 open,fclose 表头文件 #include<stdio.h> 定义函数 FILE * fopen(const char * path,const char * mode); 函数说明 参数path字符串包含欲打开的文件路径及文件名,参数mode字符串则代表着流形态. mode有下列几种形态字符串: r 打开只读文件,该文件必须存在. r+ 打开可读写的文件,该文件必须存在. w 打开只写文件,若文件存在则文件长度清为0,即该文件

C语言文件操作函数大全

fopen(打开文件) 相关函数 open,fclose 表头文件 #include<stdio.h> 定义函数 FILE * fopen(const char * path,const char * mode); 函数说明 参数path字符串包含欲打开的文件路径及文件名,参数mode字符串则代表着流形态. mode有下列几种形态字符串: r 打开只读文件,该文件必须存在. r+ 打开可读写的文件,该文件必须存在. w 打开只写文件,若文件存在则文件长度清为0,即该文件内容会消失.若文件不存在

item 1:理解template类型的推导

item 1: 理解template类型的推导 一些用户对复杂的系统会忽略它怎么工作,怎么设计的,但是很高兴去知道它完成的一些事.通过这样的方式,c++中的template类型的推导取得了巨大的成功.数以万计的程序员曾传过参数给template函数,并得到了满意的结果.尽管很多那些程序员很难给出比朦胧的描述更多的东西,比如那些被推导的函数是怎么使用类型来推导的. 如果你也是其中的一员,我这有好消息和坏消息给你.好消息是template类型的推导是现代c++最令人惊叹特性之一(auto)的基础.如

04--C语言文件操作函数大全(超详细)

fopen(打开文件)相关函数 open,fclose表头文件 #include<stdio.h>定义函数 FILE * fopen(const char * path,const char * mode);函数说明 参数path字符串包含欲打开的文件路径及文件名,参数mode字符串则代表着流形态.mode有下列几种形态字符串:r 打开只读文件,该文件必须存在.r+ 打开可读写的文件,该文件必须存在.w 打开只写文件,若文件存在则文件长度清为0,即该文件内容会消失.若文件不存在则建立该文件.w