当前位置:首页 > 嵌入式 > 嵌入式云IOT技术圈
[导读]C++函数模版与重载的区别 微信公众号:杨源鑫 如果你觉得本文对你有帮助,欢迎留言探讨! 首先,先来看一个例子: #include using namespace std ; //C++函数模版两种定义方式 //template < typename T> 或 template

C++函数模版与重载的区别

微信公众号:杨源鑫
如果你觉得本文对你有帮助,欢迎留言探讨!

首先,先来看一个例子:

   
  1. #include <iostream>

  2. using namespace std ;

  3. //C++函数模版两种定义方式

  4. //template < typename T> 或 template <class T>


  5. template <typename T1>

  6. T1 check_max(T1 x, T1 y);


  7. template <class T>

  8. T print_value(T x, T y);




  9. //C++重载

  10. int add(int x,int y);

  11. int add(int x,int y,int z);

  12. string add(string str , string str1 , string str2);


  13. int main(void)

  14. {

  15. int x = 33;

  16. int y = 44;

  17. long l1 = 333, l2 = 444;

  18. float f1 = 3.14, f2 = 3.15926;


  19. //系统会自动识别类型 T1为int类型

  20. cout << "max(x, y) = " << check_max(x, y) << endl;

  21. //系统会自动识别类型 T1为long类型

  22. cout << "max(x, y) = " << check_max(l1, l2) << endl;

  23. //系统会自动识别类型 T1为float类型

  24. cout << "max(x, y) = " << check_max(f1, f2) << endl;

  25. cout << "==========================================" << endl ;

  26. print_value(x,y);

  27. print_value(l1,l2);

  28. print_value(f1,f2);



  29. //重载的使用

  30. cout << "==========================================" << endl ;

  31. cout << add(x,y) << endl ;

  32. cout << add(x,y,x) << endl ;

  33. cout << add("hello"," ","world") << endl ;

  34. return 0;

  35. }


  36. template <typename T1>

  37. T1 check_max(T1 x, T1 y)

  38. {

  39. return x > y ? x : y;

  40. }


  41. template <typename T>

  42. T print_value(T x, T y)

  43. {

  44. cout <<"x:"<< x << endl ;

  45. cout <<"y:"<< y << endl ;

  46. }


  47. int add(int x,int y)

  48. {

  49. return x+y ;

  50. }

  51. int add(int x,int y,int z)

  52. {

  53. return x+y+z ;

  54. }

  55. string add(string str , string str1 , string str2)

  56. {

  57. return str+str1+str2 ;

  58. }

运行结果:

    从代码中我们可以学习到,模板的定义方式一般有两种,分别为:template < typename T>  或  template 。有人可能会问一个typename和一个class这里面有什么区别,其实早期的C++并没有typename这个关键字,所以不论是函数模板还是类模板,都使用class的这种定义方式,后面C++完善,于是多出了typename,用来区分定义的是函数模板还是类模板,但本质都是一样的。

      所谓的函数模板,实际上是建立一个通用的函数,其函数的类型和形参的类型不具体指定,用一个虚拟的类型来代表,这个通用的函数就成为函数模板。凡是函数体相同的函数都可以用这个模板来代替,而不必定义多个函数,只需在模板中定义一次就行了,在调用函数的时候系统会根据实参的类型来取代模板中的虚拟类型,从而实现了不同函数的功能。

      如例程所示,定义了checkmax和printvalue这两个函数模板,但我这里并没有定义相关的类,调用函数的时候也能输出正确的数值,这就说明不管是声明为typename还是class,本质都是一样的,只是我们可以人为进行区分。checkmax就是我们定义的模板函数,用来判断大小,而printvalue就是用来打印变量的数据,仅此而已。

     相对于函数重载而言,模板具有得天独厚的优势,它不需要重复定义,所以使用起来比函数重载更简洁,但应注意的一点,函数模板只适用于函数的参数个数相同而类型不同,且函数体相同的情况,如果参数的个数不同,则不能用函数模板,这就是函数模板相对于函数重载的缺陷。

     我们再对上面的程序加以修改,我们再定义一个与模板函数check_max名称一模一样的函数名字,实际上就是函数重载了,看看下面这个例子:

   
  1. #include <iostream>

  2. using namespace std ;

  3. //C++函数模版两种定义方式

  4. //template < typename T> 或 template <class T>

  5. template <typename T1>

  6. T1 check_max(T1 x, T1 y);

  7. //C++重载

  8. int check_max(int x,int y);


  9. int main(void)

  10. {

  11. int x = 33;

  12. int y = 44;

  13. long l1 = 333, l2 = 444;

  14. float f1 = 3.14, f2 = 3.15926;


  15. //系统会优先调用重载函数,而不是模板函数

  16. cout << "max(x, y) = " << check_max(x, y) << endl;

  17. //系统会自动识别类型 T1为long类型

  18. cout << "max(x, y) = " << check_max(l1, l2) << endl;

  19. //系统会自动识别类型 T1为float类型

  20. cout << "max(x, y) = " << check_max(f1, f2) << endl;

  21. cout << "==========================================" << endl ;

  22. return 0;

  23. }


  24. template <typename T1>

  25. T1 check_max(T1 x, T1 y)

  26. {

  27. cout << "调用模板函数打印" << endl ;

  28. return x > y ? x : y;

  29. }


  30. int check_max(int x,int y)

  31. {

  32. cout << "调用重载函数打印" << endl ;

  33. return x > y ? x : y ;

  34. }

运行结果:

    如例程所示,我们定义了一个重载函数,形参和返回值都为int类型的check_max函数,当我们在main函数里调用这个函数,如果传入为int的形参的时候,此时和模板发生了冲突,调用了重载函数来打印,而不是调用模板。 由此我们得出结论:当模板和重载冲突的时候 ,就优先调用重载。


免责声明:本文内容由21ic获得授权后发布,版权归原作者所有,本平台仅提供信息存储服务。文章仅代表作者个人观点,不代表本平台立场,如有问题,请联系我们,谢谢!

本站声明: 本文章由作者或相关机构授权发布,目的在于传递更多信息,并不代表本站赞同其观点,本站亦不保证或承诺内容真实性等。需要转载请联系该专栏作者,如若文章内容侵犯您的权益,请及时联系本站删除。
换一批
延伸阅读

高性能计算领域,分支预测失败导致的流水线清空是现代CPU的致命弱点。当处理器遇到条件分支时,其分支预测单元会基于历史数据猜测执行路径,若预测错误将导致20-40个时钟周期的浪费。无分支编程技术通过消除条件跳转指令,使代码...

关键字: C C++ 基准

幂等性原本是一个数学概念,指一个函数或操作无论执行一次还是多次,其结果都保持一致。在RESTful API的语境中,这一概念被赋予了新的内涵:无论客户端发起一次还是多次相同的请求,服务器端对资源状态的影响始终保持一致^。...

关键字: 幂等性 函数

在资源受限的嵌入式系统中,C++继承机制常被视为"奢侈特性",但合理运用可显著提升代码复用性与可维护性。本文从嵌入式开发特性出发,解析继承机制的最佳应用场景与实践准则。

关键字: C++ 嵌入式开发

在大型C/C++项目开发中,头文件依赖管理是决定编译效率与代码可维护性的关键因素。不当的头文件组织会导致编译时间指数级增长、隐藏的编译错误,甚至破坏模块间的隔离性。本文通过分析典型问题,提出有效的依赖管理策略与编译隔离方...

关键字: 模块化设计 头文件 编译隔离 C++

在面向对象程序设计领域,设计模式是解决特定问题的经典方案。桥接模式(Bridge Pattern)作为一种结构型设计模式,其核心思想是将抽象部分与实现部分分离,使两者可以独立变化。这种分离机制在系统需要同时应对多个维度的...

关键字: C++ 桥接模式

这个存储库包含Piper RL的简单演示代码,展示了如何使用Piper RL来训练一个简单的任务:到达目标,该任务要求Piper的夹持器的中心达到指定的目标位置,而不要求Piper的末端执行器的结束姿势,通过简单的奖励函...

关键字: 存储库 Piper RL 函数

北京2025年12月15日 /美通社/ -- 亚马逊云科技在2025 re:Invent全球大会上宣布推出两项全新的Amazon Lambda功能——Amazon Lambda持久化函数(Amazon Lambda Du...

关键字: 亚马逊 函数 应用程序 SERVER

北京——2025年12月15日 亚马逊云科技在2025 re:Invent全球大会上宣布推出两项全新的Amazon Lambda功能——Amazon Lambda持久化函数(Amazon Lambda Durable F...

关键字: AI 编程模型 函数

北京2025年11月27日 /美通社/ -- 秉承"全球专家、卓越智慧"的理念,由 CSDN 与奇点智能研究院举办的「2025 全球 C++ 及系统软件技术大会」将于 12 月 12-13 日在北京金隅喜来登大酒店正式举...

关键字: 系统软件 C++ AI ST

C++编程语言中的一种强大功能是模板,它允许我们编写泛型代码,使得我们的函数或类可以对多种数据类型进行操作。在这篇文章中,我们将详细介绍如何在C++中使用模板来编写泛型代码。

关键字: C++ 编程语言
关闭