学习处理模板化基类内的名称
2014-11-07 15:31
429 查看
1.从面向对象的C++转向模板C++时继承可能遭遇问题:由于基类模板可能被特化,而该特化版本肯可能会改变成员,因此C++拒绝在模板基类中寻找继承而来的名称
2.实例:假设信息传送到不同的公司去,传送方式包括明文传送和密文传送,采用模板类的设计方法;
如果想要添加发送信息时记录信息的功能,采用继承的方式:
改进方法
(1)在基类函数调用动作之前加上this指针:
(2)使用using 声明式在类内使用基类命名空间:
(3)如果有一个类和模板类相似,但是结构不同,可以使用模板全特化,这样当该模板转化为特定的模板参数类型时就调用该特化版本定义格式:
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) { ... } };
相关文章推荐
- 条款43:学习处理模板化基类内的名称
- effective C++ 条款 43:学习处理模板化基类内的名称
- Effective C++ 条款43 学习处理模板化基类内的名称
- Item 43: 学习处理模板化基类内的名称
- Effective C++学习笔记_条款43:学习处理模板化基类内的名称
- 条款43:学习处理模板化基类内的名称
- Effective C++笔记_条款43 学习处理模板化基类内的名称
- 《Effective C++》读书笔记之item43:学习处理模板化基类内的名称
- 读书笔记_Effective_C++_条款四十三:学习处理模板化基类的名称
- Effective C++ -----条款43:学习处理模板化基类内的名称
- Effective C++:条款43:学习处理模板化基类内的名称
- Effective C++笔记_条款43 学习处理模板化基类内的名称
- 条款43:学习处理模板化基类内的名称
- 条款43:学习处理模板化基类内的名称
- 《Effective C++》:条款43:学习处理模板化基类内的名称
- 条款43:学习处理模板化基类内的名称
- 条款43:学习处理模板化基类的名称
- Effective C++ Item 43 学习处理模板化基类内的名称
- Effective C++ Item 43 学习处理模板化基类内的名称
- 条款43、学习处理模版化基类内的名称