• C++——模板


    目录

    泛型编程

    函数模板

    函数模板概念

    函数模板格式

    类模板

    类模板的定义格式

    类模板的实例化


    泛型编程

            泛型编程是什么呢?泛型编程:编写与类型无关的通用代码,是代码复用的一种手段。模板是泛型编程的基础。型就是类型,不管是内置类型还是自定义类型,他们在类中还是在函数中都有他们的一席之地,在之前的学习中,已经知道了函数重载。

    1. void Swap(int &left, int &right)
    2. {
    3. int temp = left;
    4. left = right;
    5. right = temp;
    6. }
    7. void Swap(double &left, double &right)
    8. {
    9. double temp = left;
    10. left = right;
    11. right = temp;
    12. }
    13. void Swap(char &left, char &right)
    14. {
    15. char temp = left;
    16. left = right;
    17. right = temp;
    18. }

    函数重载已经帮我们实现了这一功能,但是还有美中不足的地方:

    1. 重载的函数仅仅是类型不同,代码复用率比较低,只要有新类型出现时,就需要用户自己增加对应的函数。这里只有三个类型,但是以后的应用场景可不止三个类型
    2. 代码的可维护性比较低,一个出错可能所有的重载均出错。

            这个时候就有了一个东西叫做“模板”,说白了就是一个“模子”,让编译器根据不同的类型利用这个“模子”来生成代码。更容易懂的一个说法就是我们中国的四大发明中的活字印刷,先把每个字的模型造出来,之后可以重复的使用。


    函数模板

    函数模板概念

            函数模板代表了一个函数家族,该函数模板与类型无关,在使用时被参数化,根据实参类型产生函数的特定类型版本。

    函数模板格式

    1. // template
    2. // 返回值类型 函数名(参数列表)
    3. // {}
    4. // 有了模板就可以重新写一下Swap这个函数
    5. template<typename T> // 这就是模板,T既是类型,相当于把类型变成了模板,不仅可以用T,也可以是K,V,就是个名字
    6. void Swap(T &left, T &right) // 无论left和right是什么类型的,传入什么类型就是什么类型
    7. {
    8. T temp = left;
    9. left = right;
    10. right = temp;
    11. }

    所以他们底层调用的也不是同一个函数。

    【注意】:typename是用来定义模板参数关键字,也可以使用class,template

    1. // 如果参数有两个参数,但是传入的类型不同
    2. T Add(const T& left, const T& right) // 引用常量必须用const修饰
    3. {
    4. return left + right;
    5. }
    6. int main()
    7. {
    8. // 编译器自动推演,隐式实例化
    9. // cout << Add(1.0, 2) << endl; 这样是错误的
    10. cout << Add((int)1.0, 2) << endl;
    11. cout << Add(1.0, (double)2) << endl;
    12. // 显示实例化
    13. cout << Add<int>(1.0, 2) << endl;
    14. cout << Add<double>(1.0, 2) << endl;
    15. }

    类模板

    类模板的定义格式

    1. template<class T1, class T2, ..., class Tn>
    2. class 类模板名
    3. {
    4. // 类内成员定义
    5. };

    类模板的实例化

            类模板实例化与函数模板实例化不同,类模板实例化需要在类模板名字后跟<>,然后将实例化的类型放在<>中即可,类模板名字不是真正的类,而实例化的结果才是真正的类。
    1. // ClassName是类名,ClassName才是类型,这是两个类型
    2. ClassName<int> CNi;
    3. ClassName<double> CNd;

    【注意】:模板不支持分离编译,如声明放在.h,定义放在.cpp;但是放在同一个文件就可以。


            

    简单介绍一下模板的使用,以保证后面知识的讲解。

  • 相关阅读:
    22.3D等距社交媒体菜单的悬停特效
    Nexus存储库管理器搭建-Maven私服
    在线漫画app开发,更好地保证用户的个性化体验
    军训场KL
    ubuntu服务器启动报错UNEXPECTED INCONSISTENCY解决方法
    程序员的浪漫:如何用java代码画❤️表白呢?
    0-1背包问题
    2、JVM:学习路线图
    在Linux/Ubuntu/Debian中使用 `tee` 命令将输出显示在终端并写入文件中
    基于Java的宠物商店管理系统设计与实现(源码+lw+部署文档+讲解等)
  • 原文地址:https://blog.csdn.net/m0_64607843/article/details/133099701