C++泛型编程,模板(一)函数模板

简介: C++泛型编程,模板(一)函数模板

模板的概念

模板就是建立通用的模具,大大提高复用性

例如生活中的模板:

一寸照片模板,PPT模板等。

模板的特点:

  • 模板不可以直接使用,它只是一个框架
  • 模板的通用并不是万能的

函数模板

  • C++另一种编程思想称为 ==泛型编程== ,主要利用的技术就是模板
  • C++提供两种模板机制:函数模板类模板

函数模板语法

函数模板作用:

建立一个通用函数,其函数返回值类型和形参类型可以不具体制定,用一个虚拟的类型来代表。

语法:

template<typenameT>

函数声明或定义

解释:

template  ---  声明创建模板

typename  --- 表面其后面的符号是一种数据类型,可以用class代替

T    ---   通用的数据类型,名称可以替换,通常为大写字母

示例:

//交换整型函数

voidswapInt(int&a, int&b) {

   inttemp=a;

   a=b;

   b=temp;

}

//交换浮点型函数

voidswapDouble(double&a, double&b) {

   doubletemp=a;

   a=b;

   b=temp;

}

利用模板提供通用的交换函数

//利用模板提供通用的交换函数

template<typenameT>//声明一个模板,告诉编译器后面代码紧跟着的代码T不要报错

voidmySwap(T&a, T&b)

{

   Ttemp=a;

   a=b;

   b=temp;

}

voidtest01()

{

   inta=10;

   intb=20;

   //利用模板实现交换

   //1、自动类型推导

   mySwap(a, b);

   //2、显示指定类型

   mySwap<int>(a, b);

   cout<<"a = "<<a<<endl;

   cout<<"b = "<<b<<endl;

}

intmain() {

   test01();

   system("pause");

   return0;

}

总结:

  • 函数模板利用关键字 template
  • 使用函数模板有两种方式:自动类型推导、显示指定类型
  • 模板的目的是为了提高复用性,将类型参数化

函数模板注意事项

注意事项:

  • 自动类型推导,必须推导出一致的数据类型T,才可以使用
  • 模板必须要确定出T的数据类型,才可以使用

示例:

1、自动类型推导,必须推导出一致的数据类型T,才可以使用

//利用模板提供通用的交换函数

template<classT>

voidmySwap(T&a, T&b)

{

   Ttemp=a;

   a=b;

   b=temp;

}

// 1、自动类型推导,必须推导出一致的数据类型T,才可以使用

voidtest01()

{

   inta=10;

   intb=20;

   charc='c';

   mySwap(a, b); // 正确,可以推导出一致的T

   //mySwap(a, c); // 错误,推导不出一致的T类型

}

intmain() {

   test01();

   

   system("pause");

   return0;

}

2、模板必须要确定出T的数据类型,才可以使用

// 2、模板必须要确定出T的数据类型,才可以使用

template<classT>

voidfunc()

{

   cout<<"func 调用"<<endl;

}

voidtest02()

{

   //func(); //错误,模板不能独立使用,即使没有用到T,也必须确定出T的类型

   func<int>(); //利用显示指定类型的方式,给T一个类型,才可以使用该模板

}

intmain() {

   test02();

   system("pause");

   return0;

}

总结:

  • 使用模板时必须确定出通用数据类型T,并且能够推导出一致的类型

函数模板案例

案例描述:

  • 利用函数模板封装一个排序的函数,可以对不同数据类型数组进行排序
  • 排序规则从大到小,排序算法为选择排序
  • 分别利用char数组int数组进行测试

示例:

//交换的函数模板

template<typenameT>

voidmySwap(T&a, T&b)

{

   Ttemp=a;

   a=b;

   b=temp;

}

template<classT>// 也可以替换成typename

//利用选择排序,进行对数组从大到小的排序

voidmySort(Tarr[], intlen)

{

   for (inti=0; i<len; i++)

   {

       intmax=i; //最大数的下标

       for (intj=i+1; j<len; j++)

       {

           if (arr[max] <arr[j])

           {

               max=j;

           }

       }

       if (max!=i) //如果最大数的下标不是i,交换两者

       {

           mySwap(arr[max], arr[i]);

       }

   }

}

template<typenameT>

voidprintArray(Tarr[], intlen) {

   for (inti=0; i<len; i++) {

       cout<<arr[i] <<" ";

   }

   cout<<endl;

}

voidtest01()

{

   //测试char数组

   charcharArr[] ="bdcfeagh";

   intnum=sizeof(charArr) /sizeof(char);

   mySort(charArr, num);

   printArray(charArr, num);

}

voidtest02()

{

   //测试int数组

   intintArr[] = { 7, 5, 8, 1, 3, 9, 2, 4, 6 };

   intnum=sizeof(intArr) /sizeof(int);

   mySort(intArr, num);

   printArray(intArr, num);

}

intmain() {

   test01();

   test02();

   system("pause");

   return0;

}

总结:模板可以提高代码复用,需要熟练掌握


目录
相关文章
|
3月前
|
存储 C++ UED
【实战指南】4步实现C++插件化编程,轻松实现功能定制与扩展
本文介绍了如何通过四步实现C++插件化编程,实现功能定制与扩展。主要内容包括引言、概述、需求分析、设计方案、详细设计、验证和总结。通过动态加载功能模块,实现软件的高度灵活性和可扩展性,支持快速定制和市场变化响应。具体步骤涉及配置文件构建、模块编译、动态库入口实现和主程序加载。验证部分展示了模块加载成功的日志和配置信息。总结中强调了插件化编程的优势及其在多个方面的应用。
463 67
|
2月前
|
安全 编译器 C++
【C++11】可变模板参数详解
本文详细介绍了C++11引入的可变模板参数,这是一种允许模板接受任意数量和类型参数的强大工具。文章从基本概念入手,讲解了可变模板参数的语法、参数包的展开方法,以及如何结合递归调用、折叠表达式等技术实现高效编程。通过具体示例,如打印任意数量参数、类型安全的`printf`替代方案等,展示了其在实际开发中的应用。最后,文章讨论了性能优化策略和常见问题,帮助读者更好地理解和使用这一高级C++特性。
72 4
|
2月前
|
算法 编译器 C++
【C++】模板详细讲解(含反向迭代器)
C++模板是泛型编程的核心,允许编写与类型无关的代码,提高代码复用性和灵活性。模板分为函数模板和类模板,支持隐式和显式实例化,以及特化(全特化和偏特化)。C++标准库广泛使用模板,如容器、迭代器、算法和函数对象等,以支持高效、灵活的编程。反向迭代器通过对正向迭代器的封装,实现了逆序遍历的功能。
39 3
|
3月前
|
安全 程序员 编译器
【实战经验】17个C++编程常见错误及其解决方案
想必不少程序员都有类似的经历:辛苦敲完项目代码,内心满是对作品品质的自信,然而当静态扫描工具登场时,却揭示出诸多隐藏的警告问题。为了让自己的编程之路更加顺畅,也为了持续精进技艺,我想借此机会汇总分享那些常被我们无意间忽视却又导致警告的编程小细节,以此作为对未来的自我警示和提升。
418 12
|
2月前
|
消息中间件 存储 安全
|
2月前
|
编译器 C++
【c++】模板详解(1)
本文介绍了C++中的模板概念,包括函数模板和类模板,强调了模板作为泛型编程基础的重要性。函数模板允许创建类型无关的函数,类模板则能根据不同的类型生成不同的类。文章通过具体示例详细解释了模板的定义、实例化及匹配原则,帮助读者理解模板机制,为学习STL打下基础。
35 0
|
3月前
|
程序员 C++ 容器
在 C++中,realloc 函数返回 NULL 时,需要手动释放原来的内存吗?
在 C++ 中,当 realloc 函数返回 NULL 时,表示内存重新分配失败,但原内存块仍然有效,因此需要手动释放原来的内存,以避免内存泄漏。
|
3月前
|
编译器 程序员 C++
【C++打怪之路Lv7】-- 模板初阶
【C++打怪之路Lv7】-- 模板初阶
26 1
|
3月前
|
存储 前端开发 C++
C++ 多线程之带返回值的线程处理函数
这篇文章介绍了在C++中使用`async`函数、`packaged_task`和`promise`三种方法来创建带返回值的线程处理函数。
113 6
|
3月前
|
C++
C++ 多线程之线程管理函数
这篇文章介绍了C++中多线程编程的几个关键函数,包括获取线程ID的`get_id()`,延时函数`sleep_for()`,线程让步函数`yield()`,以及阻塞线程直到指定时间的`sleep_until()`。
51 0