CRTP奇异递归模型——用普通函数的性能来实现C++的多态性(静态多态)

CRTP 奇异递归模板

**CRTP (奇异递归模板)**能以一种小于虚函数开销的方式来实现多态,但是这种多态是静态多态Static Ploymorphism,就是类型的确定时发生在编译期的,这种写法能减小虚函数的性能开销,但是他的缺陷是不适用于哪些运行时的多态,即类型是在运行时才能确定的情况是不适用于静态多态的。

比如如下一段代码

#include <iostream>

using namespace std;

struct Animal{
    virtual void i_am_who() = 0;
};

struct Cat: public Animal{
    void i_am_who() override{
        cout<<"I am cat! miao miao~"<<endl;
    }
};

struct Dog: public Animal{
    void i_am_who() override{
        cout<<"I am dog! wang wang~"<<endl;
    }
};

int main(){
    Animal* cat = new Cat;
    Animal* dog = new Dog;
    cat->i_am_who();
    dog->i_am_who();
}

这就是一个简单的利用虚函数来实现多态,这种多态的实现是利用在RTTI虚表来进行具体函数的跳转,是一种运行时的动态多态Dynamic Polymorphism优点很明显,能封装具体的类型,通过一个统一的接口而调用不同方法,但是实现虚函数需要的性能开销相比于普通函数,往往是普通函数的几倍。而对于静态多态,即类型在编译器就可以确定的,可以利用CRTP来实现静态多态,达到上面的目的,并且其性能开销也很小,跟普通函数性能相仿

#include <iostream>

using namespace std;

template<class specific_animal>
struct Animal{
    void i_am_who(){
        static_cast<specific_animal&>(*this).i_am_who();
    }
};

struct Cat: public Animal<Cat>{
    void i_am_who(){
        cout<<"I am cat! miao miao~"<<endl;
    }
};

struct Dog: public Animal<Dog>{
    void i_am_who(){
        cout<<"I am dog! wang wang~"<<endl;
    }
};

int main(){
    Animal<Cat>* cat = new Cat();
    Animal<Dog>* dog = new Dog();
    cat->i_am_who();
    dog->i_am_who();
}
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值