c++学习笔记(9)-模板基础

2023-12-26 16:34:03

1、概念

C++中的模板是一种通用的编程工具,可以生成可应对多种数据类型的代码。通过使用模板,可以编写可以处理不同类型数据的函数和类,并提高代码的可重用性和灵活性。

2、模板类型

2.1、函数模板

下面是一个简单的函数模板,用于计算两个数字的最大值:

template <typename T>
T max(T a, T b) {
    return (a > b) ? a : b;
}

2.2、类模板

下面是一个简单的类模板,用于实现通用的堆栈数据结构:

template <typename T>
class Stack {
private:
    vector<T> data;
public:
    void push(T value) {
        data.push_back(value);
    }
    void pop() {
        data.pop_back();
    }
};

2.3、成员函数模板

下面是一个简单的类模板,其中包含一个成员函数模板,用于计算两个数字的最大值:

template <typename T>
class Calculator {
public:
    T max(T a, T b) {
        return (a > b) ? a : b;
    }
};

2.4、非类型模板

下面是一个简单的类模板,其中包含一个非类型模板参数N,用于指定数组的大小:

template <typename T, int N>
class Array {
private:
    T data[N];
public:
    T& operator[](int i) {
        return data[i];
    }
};

2.5、类型别名

这个类型模板会把任意类型映射到 int类型。

template <typename... Ts>
using int_t = int;
//使用
int_t<float> say(){
    return 18;
}

3、特化

C++模板中的特化(template specialization)是一种允许为特定类型或值参数提供自定义实现的机制,当需要针对某些类型或值参数提供不同于通用实现的行为时,可以使用模板特化来实现这一点。模板特化包括全局特化和部分特化。其中,全特化指的是所有的模板参数都被指定了具体的类型或值;偏特化指的是部分模板参数被指定了具体的类型或值。

#include <iostream>
using namespace std;

// 通用模板
template <typename T1, typename T2>
class Printer {
public:
    void print() {
        cout << "通用模板" << endl;
    }
};

// 全特化版本
template <>
class Printer<int, double> {
public:
    void print() {
        cout << "全特化模板" << endl;
    }
};

// 偏特化版本
template <typename T>
class Printer<T, double> {
public:
    void print() {
        cout << "偏特化模板" << endl;
    }
};

int main() {
    Printer<double, float> obj1;
    obj1.print();//输出:通用模板

    Printer<int, double> obj2;
    obj2.print();//输出:全特化模板

    Printer<char, double> obj3;
    obj3.print();//输出:偏特化模板

    return 0;
}

4、函数模板匹配

C++中,模板函数匹配(Function Template Argument Deduction)规则如下:
首先查找到函数名匹配的模板;接着根据函数模板参数列表(即模板参数类型及其数量、模板参数的默认值等)进行匹配;当发现有多个匹配的模板的时候,选择匹配度最高的函数模板作为最终的函数模板:全特化>偏特化>通用模板。
image.png

文章来源:https://blog.csdn.net/fanrongwoaini/article/details/135223417
本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。