C++中函数模板与类模板的简单使用及区别介绍

 更新时间:2025年03月22日 10:39:32   作者:CoderIsArt  
这篇文章介绍了C++中的模板机制,包括函数模板和类模板的概念、语法和实际应用,函数模板通过类型参数实现泛型操作,而类模板允许创建可处理多种数据类型的类,文章还讨论了模板的关键区别、注意事项以及它们在实际编程中的应用,感兴趣的朋友一起看看吧

在C++中,模板是实现泛型编程的核心机制,允许开发者编写与类型无关的代码。以下是函数模板和类模板的详细介绍及实际示例。

一、函数模板

定义

函数模板通过参数化类型实现泛型操作,只需编写一次代码即可处理多种数据类型,避免重复。

语法

template<typename T>
返回类型 函数名(参数列表) { ... }

typename T 表示类型占位符,编译时根据实参类型自动实例化。

真实示例

‌交换两个值(swap

template<typename T>
void swap(T &a, T &b) {
    T temp = a;
    a = b;
    b = temp;
}

使用场景‌:交换任意类型的变量(如 intstring)。

int x = 1, y = 2;
swap(x, y);  // 自动推导为 swap<int>

‌求最大值(max

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

使用场景‌:比较同类型值的最大值,要求类型支持 operator>

打印数组

int nums[] = {1, 2, 3};
printArray(nums);  // 推导 T=int, N=3

二、类模板

定义

类模板允许创建可处理多种数据类型的类,成员变量和函数均可使用模板参数。

语法

template<typename T>
class 类名 {
    // 类成员使用 T 作为类型
};

真实示例

‌动态数组(Array

template<typename T>
class Array {
private:
    T* data;
    size_t size;
public:
    Array(size_t size) : size(size), data(new T[size]) {}
    ~Array() { delete[] data; }
    T& operator[](size_t index) { return data[index]; }
    size_t getSize() const { return size; }
};

使用场景‌:存储任意类型的动态数组。

Array<int> intArr(10);    // 存储 int 的数组
Array<string> strArr(5);  // 存储 string 的数组

‌键值对(Pair

template<typename T1, typename T2>
class Pair {
public:
    T1 first;
    T2 second;
    Pair(const T1 &f, const T2 &s) : first(f), second(s) {}
};

使用场景‌:组合两个不同类型的数据(如字典条目)。

Pair<string, int> student("Alice", 90);  // 姓名和分数

‌栈(Stack

template<typename T>
class Stack {
private:
    std::vector<T> elements;
public:
    void push(const T &elem) { elements.push_back(elem); }
    T pop() {
        if (elements.empty()) throw std::out_of_range("Stack is empty!");
        T elem = elements.back();
        elements.pop_back();
        return elem;
    }
};

使用场景‌:实现泛型栈结构,支持多种数据类型。

Stack<double> doubleStack;
doubleStack.push(3.14);

三、关键区别

特性函数模板类模板
类型推导自动推导参数类型(无需显式指定)必须显式指定类型(如 Stack<int>
默认模板参数支持(C++11起)支持(如 template<typename T = int>
典型应用算法(如排序、交换)容器(如数组、栈、队列)

四、注意事项 ‌

  • 编译方式‌:模板代码通常放在头文件中,因为编译器需在编译时生成具体类型的实例化代码。‌
  • 类型约束‌:模板中的操作(如 operator>)需在类型 T 中定义,否则编译失败。‌
  • 性能‌:模板在编译时展开,无运行时开销,但可能增加代码体积。

通过合理使用模板,可以大幅提升代码复用性,同时保持类型安全和高性能。例如,标准模板库(STL)中的 vectorsort 均基于模板实现。

到此这篇关于C++中函数模板与类模板的简单使用的文章就介绍到这了,更多相关C++函数模板与类模板内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

相关文章

  • 深入HRESULT与Windows Error Codes的区别详解

    深入HRESULT与Windows Error Codes的区别详解

    本篇文章是对HRESULT与Windows Error Codes的区别进行了详细的分析介绍,需要的朋友参考下
    2013-05-05
  • C++扫盲篇之指针详解

    C++扫盲篇之指针详解

    C++中一个指针的使用就已经让很多人欲哭无泪,可是更不幸的是他还有指向指针的指针,这篇文章主要给大家介绍了关于C++扫盲篇之指针的相关资料,需要的朋友可以参考下
    2022-03-03
  • c语言10个经典小程序

    c语言10个经典小程序

    c语言的经典程序,学习c语言的初学者可以参考下
    2013-01-01
  • C++实现哈夫曼树的方法

    C++实现哈夫曼树的方法

    这篇文章主要为大家详细介绍了C++实现哈夫曼树的方法,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2020-04-04
  • 基于VC 6.0使用C语言实现俄罗斯方块

    基于VC 6.0使用C语言实现俄罗斯方块

    这篇文章主要为大家详细介绍了基于VC 6.0使用C语言实现俄罗斯方块,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2018-06-06
  • C++ RBTree红黑树的性质与实现

    C++ RBTree红黑树的性质与实现

    红黑树是一种二叉搜索树,但在每个结点上增加一个存储位表示结点的颜色,可以是Red或Black;通过对任何一条从根到叶子的路径上各个结点着色方式的限制,红黑树确保没有一条路径会比其他路径长出俩倍,因而是平衡的
    2023-03-03
  • C++ decltype用法举例说明

    C++ decltype用法举例说明

    decltype是C++11添加的一个新的关键字,目的是选择并返回操作数的数据类型,重要的是,在此过程中编译器分析表达式并得到它的类型,却不实际计算表达式的值,今天通过本文给大家介绍C++ decltype用法,通过实例代码给大家介绍的非常详细,需要的朋友参考下吧
    2021-07-07
  • 错误:sem_union的存储大小未知问题的解决方法

    错误:sem_union的存储大小未知问题的解决方法

    这篇文章主要介绍了错误:sem_union的存储大小未知问题的解决方法,需要的朋友可以参考下
    2016-10-10
  • C++中的函数返回值与拷贝用法

    C++中的函数返回值与拷贝用法

    这篇文章主要介绍了C++中的函数返回值与拷贝用法,具有很好的参考价值,希望对大家有所帮助。如有错误或未考虑完全的地方,望不吝赐教
    2022-11-11
  • C++基于随机数实现福彩双色球的方法示例

    C++基于随机数实现福彩双色球的方法示例

    这篇文章主要介绍了C++基于随机数实现福彩双色球的方法,结合完整实例形式分析了C++随机数算法的实现与使用技巧,需要的朋友可以参考下
    2017-06-06

最新评论