模板是编译期代码生成器,非语法糖;声明与定义须同在头文件,否则链接失败;CTAD需推导指南;auto非模板替代品;特化是替换而非重载;concept比偏特化更易维护。

C++怎么使用模板_C++泛型编程教程【高级】

模板不是语法糖,是编译期代码生成器

template<typename T> 不是在“泛化函数”,而是在告诉编译器:“等实际类型出现时,按这个蓝图现场生成一份新函数”。所以 std::vector<int>std::vector<double> 在目标文件里是两套完全独立的代码,不是共享一份逻辑。

常见错误现象:undefined reference to 'MyClass<int>::foo()' —— 因为模板定义没在头文件里,链接时找不到实例化版本。

函数模板推导 vs 类模板推导(C++17)

函数模板能自动推导参数类型,类模板默认不能。比如 std::pair(1, 3.14) 能推成 std::pair<int, double>,是因为 C++17 加了类模板推导(CTAD),但这是特例,不是通则。

使用场景:写容器包装器或工厂函数时,想省掉冗长的模板参数。

别把 auto 当模板替代品

auto 是类型占位符,只做单次推导;模板是多实例化机制。两者语义不同,混用容易误判行为。

性能影响:用 auto x = foo(); 可能触发隐式拷贝(若 foo() 返回值是临时对象且未启用 RVO),而模板函数可配合 T&& 实现移动语义。

模板特化不是重载,是完全替换

全特化(template<> struct MyTrait<int> { ... };)会彻底屏蔽主模板,偏特化(template<typename T> struct MyTrait<T*> { ... };)只匹配指针类型。但偏特化不适用于函数模板 —— 函数只有重载,没有偏特化。

容易踩的坑:以为特化后能继承主模板的静态成员或友元,其实特化体是全新类型,一切从零开始。

模板的复杂度不在语法,而在实例化时机和符号可见性。很多人卡在链接阶段,不是因为不会写 template,而是忘了头文件里必须有定义。

本文转载于:互联网 如有侵犯,请联系zhengruancom@outlook.com删除。
免责声明:正软商城发布此文仅为传递信息,不代表正软商城认同其观点或证实其描述。