C++模板编程是编写通用、可复用代码的基本能力。它通过template实现函数和类的类型参数化,支持自动类型推导与显式特化,需注意错误定位、编译期特性及渐进式学习。
C++模板编程不是“高级技巧”,而是写通用、可复用代码的基本能力。掌握它,你写的函数和类才能真正适配 int、std::string、自定义结构体,甚至未来可能出现的新类型。
普通函数只能处理固定类型,比如 int add(int a, int b) 无法直接算两个 double。模板函数通过“占位符”绕过类型绑定:
template 声明模板参数(T 是任意合法类型名,也可用 class T,二者等价)T,编译器会在调用时自动推导具体类型template
T max(T a, T b) {
return (a > b) ? a : b;
}
max(3, 7) 生成 int 版本;max(3.14, 2.71) 生成 double 版本类模板把整个类的“骨架”参数化,最典型例子是 std::vector —— 它不是某个具体类,而是一套生成类的蓝图:
template class Stack { ... };
T
Stack s1; 、Stack<:string> s2;,编译器据此生成两套独立代码模板不是万能黑箱,有时需要干预它的默认行为:
max(5, 4.2) 会报错——T 无法同时是 int 和 double),这时可手动指定:max(5, 4.2)
templ
ate class Stack { ... }; —— 这个版本只用于 char*,和其他所有 Stack 无关if constexpr(C++17 起)做条件分支刚接触模板容易踩坑,记住这几个关键点:
template)、SFINAE 等进阶特性;先写好单参数函数/类模板,再逐步扩展static_assert 加约束(如要求类型支持 比较)能让错误更早、更清楚地暴露出来
基本上就这些。模板不是语法糖,它是 C++ 支持泛型的底层支柱。写多了你会发现:真正难的不是怎么写模板,而是想清楚——这个逻辑,到底哪些部分该固定,哪些该放开给用户决定。