0

0

c++怎么实现一个基于CRTP的设计模式_C++静态多态与CRTP设计技巧

尼克

尼克

发布时间:2025-11-15 07:59:31

|

716人浏览过

|

来源于php中文网

原创

CRTP是一种通过模板实现静态多态的技术,基类以派生类为模板参数,利用static_cast在编译期调用派生类方法,避免虚函数开销;它支持接口增强、Mixin组合,广泛用于高性能C++库中。

c++怎么实现一个基于crtp的设计模式_c++静态多态与crtp设计技巧

在C++中,静态多态是一种通过模板机制实现的多态形式,与传统的虚函数动态多态不同,它在编译期完成函数绑定,避免了运行时开销。实现静态多态的核心技术之一是CRTP(Curiously Recurring Template Pattern,奇异递归模板模式)。这种设计模式不仅高效,还能用于构建灵活、可复用的基类。

什么是CRTP?

CRTP的基本结构是一个基类模板,它以派生类作为模板参数继承自身:

template 
class Base {
public:
    void interface() {
        static_cast(this)->implementation();
    }
};
class Derived : public Base {
public:
    void implementation() {
        // 具体实现
    }
};

这种“自己继承自己”的写法看似奇怪,实则有效。基类通过static_castthis指针转换为派生类指针,从而调用派生类的方法,整个过程在编译期解析,无虚表开销。

CRTP实现静态多态

使用CRTP可以模拟多态行为,但不依赖虚函数。例如,定义一个通用的数值计算基类:

立即学习C++免费学习笔记(深入)”;

template 
class VectorBase {
public:
    Vec& self() { return *static_cast(this); }
    const Vec& self() const { return *static_cast(this); }
double dot(const Vec& other) const {
    double sum = 0;
    for (size_t i = 0; i zuojiankuohaophpcn self().size(); ++i) {
        sum += self().get(i) * other.get(i);
    }
    return sum;
}

Vec operator+(const Vec& other) const {
    Vec result;
    for (size_t i = 0; i zuojiankuohaophpcn self().size(); ++i) {
        result.set(i, self().get(i) + other.get(i));
    }
    return result;
}

};

class MyVector : public VectorBase { std::vector data; public: MyVector(size_t n = 3) : data(n) {}

size_t size() const { return data.size(); }
double get(size_t i) const { return data[i]; }
void set(size_t i, double v) { data[i] = v; }

};

这样,MyVector无需重写dotoperator+,却能获得完整功能,且所有调用都在编译期展开,性能接近手写循环。

Copy Leaks
Copy Leaks

AI内容检测和分级,帮助创建和保护原创内容

下载

CRTP在接口增强中的应用

CRTP常用于为派生类自动注入通用功能,比如日志、计数、序列化等。

示例:为所有派生类添加计数功能

template 
class Countable {
    inline static int count = 0;
protected:
    Countable() { ++count; }
    ~Countable() { --count; }
public:
    static int get_count() {
        return count;
    }
};

class Widget : public Countable { // 构造/析构自动被统计 };

每次创建Widget对象,计数自动增加,无需手动管理。

CRTP与混合继承(Mixin)结合

CRTP非常适合实现Mixin风格的设计,多个功能模块可以组合使用:

template  class Serializable {};
template  class Observable {};
template  class Pooled {};

class Sensor : public Serializable , public Observable , public Countable { // 获得序列化、观察、计数能力 };

每个Mixin模板通过CRTP访问派生类数据,实现高度内聚的功能扩展。

基本上就这些。CRTP利用模板和静态分发,在不牺牲性能的前提下提供多态性和代码复用,是现代C++中实现静态多态的重要手段。关键在于理解“基类操作派生类”的反向控制逻辑,并合理设计接口契约。虽然调试稍复杂,但其效率和灵活性在高性能库(如Eigen)中已被广泛验证。

相关专题

更多
java多态详细介绍
java多态详细介绍

本专题整合了java多态相关内容,阅读专题下面的文章了解更多详细内容。

15

2025.11.27

c++怎么把double转成int
c++怎么把double转成int

本专题整合了 c++ double相关教程,阅读专题下面的文章了解更多详细内容。

52

2025.08.29

C++中int、float和double的区别
C++中int、float和double的区别

本专题整合了c++中int和double的区别,阅读专题下面的文章了解更多详细内容。

98

2025.10.23

硬盘接口类型介绍
硬盘接口类型介绍

硬盘接口类型有IDE、SATA、SCSI、Fibre Channel、USB、eSATA、mSATA、PCIe等等。详细介绍:1、IDE接口是一种并行接口,主要用于连接硬盘和光驱等设备,它主要有两种类型:ATA和ATAPI,IDE接口已经逐渐被SATA接口;2、SATA接口是一种串行接口,相较于IDE接口,它具有更高的传输速度、更低的功耗和更小的体积;3、SCSI接口等等。

1018

2023.10.19

PHP接口编写教程
PHP接口编写教程

本专题整合了PHP接口编写教程,阅读专题下面的文章了解更多详细内容。

63

2025.10.17

php8.4实现接口限流的教程
php8.4实现接口限流的教程

PHP8.4本身不内置限流功能,需借助Redis(令牌桶)或Swoole(漏桶)实现;文件锁因I/O瓶颈、无跨机共享、秒级精度等缺陷不适用高并发场景。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

405

2025.12.29

class在c语言中的意思
class在c语言中的意思

在C语言中,"class" 是一个关键字,用于定义一个类。想了解更多class的相关内容,可以阅读本专题下面的文章。

465

2024.01.03

python中class的含义
python中class的含义

本专题整合了python中class的相关内容,阅读专题下面的文章了解更多详细内容。

12

2025.12.06

Golang gRPC 服务开发与Protobuf实战
Golang gRPC 服务开发与Protobuf实战

本专题系统讲解 Golang 在 gRPC 服务开发中的完整实践,涵盖 Protobuf 定义与代码生成、gRPC 服务端与客户端实现、流式 RPC(Unary/Server/Client/Bidirectional)、错误处理、拦截器、中间件以及与 HTTP/REST 的对接方案。通过实际案例,帮助学习者掌握 使用 Go 构建高性能、强类型、可扩展的 RPC 服务体系,适用于微服务与内部系统通信场景。

8

2026.01.15

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
C# 教程
C# 教程

共94课时 | 6.8万人学习

C 教程
C 教程

共75课时 | 4万人学习

C++教程
C++教程

共115课时 | 12.3万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号