CRTP通过派生类作为模板参数继承基类实现静态多态,避免虚函数开销。1. 基类用template定义,派生类继承Base;2. 成员函数通过static_cast调用具体实现,编译期解析;3. 用于替代虚函数、实现混入功能(如计数、日志)、生成比较操作符等;4. 优势为零运行时开销、支持泛型、利于内联;5. 缺点包括无法动态切换行为、模板膨胀和复杂错误信息。适合性能敏感与库设计场景。
CRTP(Curiously Recurring Template Pattern),中文常译为“奇异递归模板模式”,是C++模板编程中一种重要的惯用法。它通过让基类以派生类作为模板参数来继承自身,实现静态多态,在不使用虚函数的情况下完成类似多态的行为,从而提升性能并减少运行时开销。
CRTP的核心形式如下:
template
class Base {
public:
void interface() {
static_cast(this)->implementation();
}
void func() {
interface();
}
};
class Derived : public Base{
public:
void implementation() {
// 具体实现
}
};
这里,Base 是一个类模板,接受一个类型参数 Derived,而 Derived 类继承自 Base
由于调用是通过 static_cast 在编译期解析的,所以没有虚函数表的开销,属于静态多态,效率更高。
CRTP在实际开发中有多个高级用途,常见于库设计和性能敏感场景。
1. 静态多态替代虚函数
2. 实现混入(Mixin)功能
template
class Counter {
private:
inline static int count = 0;
public:
Counter() { ++count; }
~Counter() { --count; }
static int get_count() { return count; }
};
class MyClass : public Counter{ };
// 每次创建MyClass实例,计数自动增加
3. 接口统一与代码生成
template
class Comparable {
public:
bool operator>=(const T& other) const {
return !static_cast(this)->operator<(other);
}
bool operator>(const T& other) const {
return other < *static_cast(this);
}
// 可继续扩展 ==, != 等
};
class Value : public Comparable{
int data;
public:
bool operator<(const Value& other) const {
return data < other.data;
}
};
优势:
注意事项:
基本上就这些。CRTP是一种强大但需谨慎使用的技巧,适合在追求性能、构建基础库或实现通用组件时采用。掌握它能显著提升C++模板编程的能力。