C++中函数模板的用法详细解析_C 语言

定义

我们知道函数的重载可以实现一个函数名多用,将功能相同或者类似函数用同一个名来定义。这样可以简化函数的调用形式,但是程序中,仍然需要分别定义每一个函数。

C++提供的函数模板可以更加简化这个过程。

所谓函数模板实际上是建立一个通用函数,其涵涵素类型额形参类型不具体指定,用一个虚拟的类型来代表,这个通用函数就称为函数模板。

凡是函数体相同的函数都可以用这个模板来代替,不必定义多个函数,只需要在模板中定义一次即可。在调用函数时,系统会根据实参的类型来取代模板中的虚拟类型,从而实现了不同函数的功能。

定义函数模板的一般形式为:

复制代码 代码如下:

template <typename T>
通用函数定义

或者

复制代码 代码如下:

template <class T>
通用函数定义

下面,我们来对比一下使用普通函数,使用函数的重载,以及使用函数的模板时的情况:

该段代码用于解决不用的类型数据相加的问题

使用多个普通函数
=============示例代码1.1==============

复制代码 代码如下:

#include<iostream>
using namespace std;
int int_add(int a,int b)                              //定义函数int_add用于int型数据相加
{
 int c;
 c=a+b;
 return c;
}
double dou_add(double a,double b)     //定义函数dou_add用于double型函数相加
{
 double c;
 c=a+b;
 return c;
}
int main()
{
 cout<<int_add(5,3)<<endl;              //调用int_add函数
 cout<<dou_add(5.35,5.5)<<endl;  //调用dou_add函数
 return 0;
}

使用构造函数
===============示例代码1.2===============

复制代码 代码如下:

#include<iostream>
using namespace std;
int n_add(int a,int b)                              //定义函数n_add用于int型数据相加
{
 int c;
 c=a+b;
 return c;
}
double n_add(double a,double b)    //定义函数n_add用于double型函数相加
{
 double c;
 c=a+b;
 return c;
}
int main()
{
 cout<<n_add(5,3)<<endl;             //调用n_add函数
 cout<<n_add(5.35,5.5)<<endl;   //调用n_add函数
 return 0;
}

使用函数模板
===============示例代码1.3===================

复制代码 代码如下:

#include<iostream>
using namespace std;
template<typename T>
T n_add(T a,T b)
{
 T c;
 c=a+b;
 return c;
}
int main()
{
 cout<<n_add(5,3)<<endl;
 cout<<n_add(5.35,5.5)<<endl;
 return 0;
}

分析:首先分析示例代码1.1,该代码根据不同的的数据(int和double两种)相加,分别定义了两个不同的函数int_add和dou_add,当不同类型的数据相加时,我们人工的设定使用对应的函数进行操作。

示例代码1.2相比1.1而言,在函数的调用形式上进行了简化,使用了函数的重载技术,对于所有的数据,统一使用函数n_add进行操作,编译系统会根据数据的类型自动调用对应的函数。

示例代码1.3相比1.2而言,则有在函数体上进行了简化,如果我们使用了函数模板,我们就没有必要去一一书写对应的函数,我们只需要构造相应的模板,然后系统会自动判断数据的类型,然后替代对应的虚拟类型,

比如,当操作n_add(5.35,5.5)时,系统会自动判断数据为doubl型,然后就会将函数模板中的T替换成double:

也就相当于构造了函数:

复制代码 代码如下:

int n_add(int a,int b)                            
{
 int c;
 c=a+b;
 return c;
}

时间: 2024-09-17 03:28:58

C++中函数模板的用法详细解析_C 语言的相关文章

C/C++中可变参数的用法详细解析_C 语言

可变参数即表示参数个数可以变化,可多可少,也表示参数的类型也可以变化,可以是int,double还可以是char*,类,结构体等等.可变参数是实现printf(),sprintf()等函数的关键之处,也可以用可变参数来对任意数量的数据进行求和,求平均值带来方便(不然就用数组或每种写个重载).在C#中有专门的关键字parame,但在C,C++并没有类似的语法,不过幸好提供这方面的处理函数,本文将重点介绍如何使用这些函数. 第一步 可变参数表示用三个点-来表示,查看printf()函数和scanf(

C++中函数的默认参数详细解析_C 语言

使用方法:(1)在函数声明或定义时,直接对参数赋值,该参数就是默认参数.(2)在函数调用时,省略部分或全部参数,这时就会使用默认参数进行代替. 注意事项:(1)一般在声明函数是设置默认参数. 如果在函数声明和定义函数时都设置了默认参数,则以函数声明的默认参数为准. 复制代码 代码如下: #include<iostream>using namespace std;int main(){ double add(double a=3.2,double b=9.6);//在函数声明时设置默认参数 co

VC中Tab control控件的用法详细解析_C 语言

1. 新建一个MFC工程, 取名MyTab, 选择Dialog based, 然后Finish. 2. 删除对话框上默认添加的三个控件. 添加Tab Control控件并在Property属性中设置ID为IDC_TABTEST 在More Styles里勾上Bottom. 调速尺寸使其布满整个对话框, 我这边Tab Control的尺寸最后为164X203. 在ClassWizard为其添加变量, 变量名为m_tab. 类型为CTabCtrl. 3. 在对话框的初始化函数OnInitDialog

c++中new的三种用法详细解析_C 语言

一. 简介new有三种使用方式:plain new,nothrow new和placement new. (1)plain new顾名思义就是普通的new,就是我们惯常使用的new.在C++中是这样定义的:    void* operator new(std::size_t) throw(std::bad_alloc);    void operator delete(void *) throw(); 提示:plain new在分配失败的情况下,抛出异常std::bad_alloc而不是返回NU

STL list链表的用法详细解析_C 语言

本文以List容器为例子,介绍了STL的基本内容,从容器到迭代器,再到普通函数,而且例子丰富,通俗易懂.不失为STL的入门文章,新手不容错过! 0 前言1 定义一个list2 使用list的成员函数push_back和push_front插入一个元素到list中3 list的成员函数empty()4 用for循环来处理list中的元素5 用STL的通用算法for_each来处理list中的元素6 用STL的通用算法count_if()来统计list中的元素个数7 使用count_if()的一个更

c语言中static和extern的用法详细解析_C 语言

一,static和extern:大工程下我们会碰到很多源文档. 文档a.c 复制代码 代码如下: static int i; //只在a文档中用int j;    //在工程里用static void init()         //只在a文档中用{}void callme()          //在工程中用{   static int sum;} 上面的全局i变量和init()函数只能用在a.c文档中,全局变量sum的作用域只在callme里.变量j和函数callme()的全局限扩充到整个

c_str()的用法详细解析_C 语言

const char *c_str();c_str()函数返回一个指向正规C字符串的指针, 内容与本string串相同. c_str()就是把string类对象转换成和c兼容的char *类型.这是为了与c语言兼容,在c语言中没有string类型,故必须通过string类对象的成员函数c_str()把string 对象转换成c中的字符串样式.注意:一定要使用strcpy()函数 等来操作方法c_str()返回的指针比如:最好不要这样:char* c;string s="1234";c

CStdioFile的用法详细解析_C 语言

关于CStdioFileCStdioFile继承自CFile,一个CStdioFile 对象代表一个用运行时函数fopen 打开的C 运行时流式文件. 流式文件是被缓冲的,而且可以以文本方式(缺省)或二进制方式打开.文本方式提供对硬回车-换行符对的特殊处理.当你将一个换行符(0x0A)写入一个文本方式的CStdioFile 对象时,字节对(0x0D,0x0A)被发送给该文件.当你读一个文件时,字节对(0x0D,0x0A)被翻译为一个字节(0x0A). CStdioFile 不支持Duplicat

C++中的friend函数详细解析_C 语言

为什么要使用友元函数 在实现类之间数据共享时,减少系统开销,提高效率.如果类A中的函数要访问类B中的成员(例如:智能指针类的实现),那么类A中该函数要是类B的友元函数.具体来说:为了使其他类的成员函数直接访问该类的私有变量.即:允许外面的类或函数去访问类的私有变量和保护变量,从而使两个类共享同一函数. 实际上具体大概有下面两种情况需要使用友元函数:(1)运算符重载的某些场合需要使用友元.(2)两个类要共享数据的时候. 使用友元函数的优缺点 优点:能够提高效率,表达简单.清晰. 缺点:友元函数破环