C++模板是编译期泛型编程机制,提供类型无关的函数和类蓝图;函数模板如max支持多类型自动推导,类模板如Stack生成独立特化类型;还支持非类型参数、模板模板参数及auto参数;定义需置于头文件以确保实例化。
C++模板是一种编译期泛型编程机制,用来编写与类型无关的代码。它不是具体的数据类型或函数,而是一套“生成代码的蓝图”——编译器根据你实际使用的类型,自动实例化出对应的函数或类。
函数模板让一个函数逻辑能处理 int、double、string 甚至自定义类等不同参数类型,避免重复写多个重载版本。
基本写法:
templateT max(T a, T b) { return (a > b) ? a : b; }
说明:
template 是模板声明,T 是占位类型名(也可用 class T,二者在模板参数中等价)max(3, 5) → 实例化为 int max(int, int);max(3.14, 2.71) → 实例化为 double max(double, double)
max<:string>("hello", "world")
max(3, 3.14)),编译器通常无法自动推导,需手动指定或重载处理类模板把整个类的成员变量和函数都参数化,典型例子是 std::vector、std::pair。
简单示例(泛型栈):
templateclass Stack { private: std::vector data; p ublic: void push(const T& x) { data.push_back(x); } T pop() { T val = data.back(); data.pop_back(); return val; } bool empty() const { return data.empty(); } };
使用方式:
Stack s1; → 编译器生成一个专用于 int 的栈类Stack<:string> s2; → 另一个独立生成的字符串栈类Stack 和 Stack 之间没有继承或转换关系除了最常用的类型参数(typename T),C++ 模板还支持:
template class Array { T arr[N]; };
template class Container> class Adapter { ... };
auto 非类型参数,可直接写 template
因为模板代码在编译期需要被实例化,编译器必须看到完整的定义(而不仅是声明)。如果把实现写在 .cpp 文件里,其他文件包含头文件后调用模板,会链接失败(找不到实例化体)。
常见做法:
#include)template class Stack; )可解决分离编译问题,但不够灵活