1.从面向对象的C++转向模板C++时继承可能遭遇问题:由于基类模板可能被特化,而该特化版本肯可能会改变成员,因此C++拒绝在模板基类中寻找继承而来的名称
2.实例:假设信息传送到不同的公司去,传送方式包括明文传送和密文传送,采用模板类的设计方法;
template<typename Company> class MsgSender{ public: ... void sendClear(const MsgInfo& info){ std::string msg; ... Company c; c.sendCleartext(msg); } void sendSecret(class MsgInfo& info) { ... } };
如果想要添加发送信息时记录信息的功能,采用继承的方式:
template<typename Company> class LoggingMsgSender:public MsgSender<Company>{ public: ... void sendClearMsg(const MsgInfo& info){ ... sendClear(info); ... } };
改进方法
(1)在基类函数调用动作之前加上this指针:
this->sendClear(info);
(2)使用using 声明式在类内使用基类命名空间:
using MesgSender<company>::sendClear(info)
(3)如果有一个类和模板类相似,但是结构不同,可以使用模板全特化,这样当该模板转化为特定的模板参数类型时就调用该特化版本定义格式:
template<> class MsgSender<CompanyZ>{ public: ... void sendSecret(class MsgInfo& info) { ... } };
时间: 2024-11-10 14:03:33