C++ 惯用法之 CRTP

背景

CRTP 是 一种 C++ 的设计方法,其巧妙的结合了继承和模板编程技术,可以用来给类提供额外的功能。

CRTP

①.概述

CRTP 的基本特征表现为:基类是一个模板类;派生类在继承该基类时,将派生类自身作为模板参数传递给基类。

②.实现示例

template<typename T>
class baseDemo
{
public:
    virtual ~baseDemo(){}
    void interface()
{
        static_cast<T*>(this)->imp();
    }
};

class derivedDemo:public baseDemo<derivedDemo>
{
public:
    void imp()
{
        cout << " hello world " << endl;
    }
};

静态多态

①.概述

多态是指同一个方法在基类和不同派生类之间有不同的实现,C++ 通过虚函数实现多态,但是虚函数会影响类的内存布局,并且虚函数的调用会增加运行时的开销。

②.静态多态

CRTP 可以实现静态多态,但本质上 CRTP 中的多个派生类并不是同一个基类,因此严格意义上不能叫多态。

template<typename T>
class baseDemo
{
public:
    virtual ~baseDemo(){}
    void interface() { static_cast<T*>(this)->imp(); }
    void imp() { cout << "imp hello world " << endl; }
};

class derivedDemo1:public baseDemo<derivedDemo1>
{
public:
    void imp(){ cout << "derivedDemo1 hello world " << endl; }
};

class derivedDemo2 :public baseDemo<derivedDemo2>
{
public:
    void imp() { cout << "derivedDemo2 hello world " << endl; }
};

template<typename T>
void funcDemo(T & base)
{
    base.interface();
}

int main()
{
    derivedDemo1 d1;
    derivedDemo2 d2;

    funcDemo(d1);
    funcDemo(d2);
   
    return 0;
}

在这里插入图片描述

代码复用

①.概述

使用 CRTP 可以把重复性的代码抽象到基类中,减少代码冗余。

②.代码示例

template<typename T>
class baseDemo
{
public:
    virtual ~baseDemo(){}
    void getType() 
{ 
        T& t = static_cast<T&>(*this);
        cout << typeid(t).name() << endl;
    }
  
};

class derivedDemo1:public baseDemo<derivedDemo1>
{
};

class derivedDemo2 :public baseDemo<derivedDemo2>
{
};

int main()
{
    derivedDemo1 d1;
    derivedDemo2 d2;

    d1.getType();
    d2.getType();
    
    return 0;
}

在这里插入图片描述

扩展既有类的功能

①.概述

使用 CRTP 可以在基类中调用派生类的成员函数,从而可以在调用前后扩展新的操作。

②.代码示例

template<typename T>
class baseDemo
{
public:
    virtual ~baseDemo() {}
    void interface()
{
        cout << "hello " << endl;
        static_cast<T*>(this)->imp();
    }
};

class derivedDemo :public baseDemo<derivedDemo>
{
public:
    void imp()
{
        cout << "derivedDemo " << endl;
    }
};

int main()
{
    derivedDemo demo;
    demo.interface();
    
    return 0;
}

在这里插入图片描述

CRTP 应用示例

应用 CRTP 可以把一个类变为单例模式,代码如下:

template<typename T>
class singlePatternTemplate
{
public:
    virtual ~singlePatternTemplate() {}
    singlePatternTemplate(const singlePatternTemplate&) = delete;
    singlePatternTemplate & operator=(const singlePatternTemplate&) = delete;

    static T& getSingleObj()
{
        static T obj;
        return obj;
    }
protected:
    singlePatternTemplate(){}
};

class derivedDemo :public singlePatternTemplate<derivedDemo>
{
    friend singlePatternTemplate<derivedDemo>;
private:
    derivedDemo(){}
};

在这里插入图片描述

  • 3
    点赞
  • 8
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
作者:(美)默里 著,王昕 译 出版日期:2004-2-1 出版社:其它 页数:208 ISBN:9787508319124 文件格式:PDF 书籍简介 本书第1版荣获美国“软件开发”杂志评选的1996年图书震撼大奖(Jolt Award),中文版自2000年推出以来,经久不衰,获得了读者的充分肯定和高度评价。 第2版与第1版相比,在章节安排上有以下改变。增加了两章:“对象的创建与使用”和“C++中的C”。前者与“对象导言”实际上是第1版“对象的演化”一 章的彻底重写,增加了近几年面向对象方和编程方的最新研究与实践的丰硕成果;后者的添加使不熟悉C的读者可以直接使用本书。删去了四章:“输入输出流 介绍”、“多重继承”、“异常处理”和“运行时类型识别”,删去的内容均为C++中较复杂的主题,作者将它们连同C++标准完成后增加的一些内容放到本书 的第2卷中,使本书的第1卷内容显得更加集中,可以供不同程度的读者选择阅读。需要强调的是,第2版的改变不仅体现在这些章节的调整上,更多的改变体现在 每一章的字里行间,包括例子的调整和练习的补充。与众不同的精心选材和认真推敲的叙述使得第2版更趋成熟。 本书是C++领域内一本权威的著作,书中的内容、讲授方、例子和练习既适合课堂教学,又适合读者自学。无论是高等院校计算机及相关专业的学生,还是业界的从业人员,以及广大的计算机爱好者,都可从阅读本书中获益。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值