CRTP通过派生类继承以自身为模板参数的基类,在编译期实现静态多态,消除虚函数开销。基类使用static_cast调用派生类方法,实现内联优化。例如Arithmetic模板为MyNumber提供add、multiply默认实现,无需虚函数。优势包括性能提升、类型安全、无虚表内存开销,适用于数学库、泛型扩展等场景。但不支持运行时多态切换,跨库传递困难,头文件依赖强,错误信息复杂。正确使用需确保派生类实现对应方法,避免模板实例化失败。

CRTP(Curiously Recurring Template Pattern),中文常译为“奇异递归模板模式”,是C++中实现静态多态的一种经典技术。它通过模板和继承的巧妙结合,在编译期完成多态行为,避免了虚函数表带来的运行时开销,是追求高性能场景下的重要工具。
什么是CRTP?
CRTP的基本形式是一个类模板派生自以其自身为模板参数的基类。虽然名字中有“递归”,但并非函数或类型的真正递归,而是一种模板实例化结构:
template<typename Derived>
class Base {
public:
void interface() {
static_cast<Derived*>(this)->implementation();
}
};
<p>class Derived : public Base<Derived> {
public:
void implementation() {
// 具体实现
}
};</p>登录后复制
在这个例子中,Base 是一个类模板,Derived 继承自 Base
静态多态如何实现?
传统多态依赖虚函数机制,在运行时通过虚表查找函数地址。而CRTP在编译期就能确定调用目标,因此称为“静态多态”。
立即学习“C++免费学习笔记(深入)”;
关键在于:基类中的 static_cast
举个实际例子:
版权声明:除非特别标注,否则均为本站原创文章,转载时请以链接形式注明文章出处。
还木有评论哦,快来抢沙发吧~