七、模板与泛型编程
条款43:学习处理模板化基类内的名称
开始,先写一个程序,它能够传送信息到若干不同的公司去。信息要么就是被译成密码,要么就是未经过加工的文字。
如果在编译期内,我们拥有足够的信息来决定哪一个信息传递到哪一家公司,就可以采用template的方法。
class CompanyA {
public:
...
void sendCleartext(const std::string& msg);
void sendEncrypted(const std::string& msg);
...
};
class CompanyB {
public:
...
void sendCleartext(const std::string& msg);
void sendEncrypted(const std::string& msg);
...
};
... // 针对其他公司设计的类
class MsgInfo { ... }; // 保存信息,以备将来产生信息
template<typename Company>
class MsgSender {
public:

本文是学习《Effective C++》条款43的心得,探讨在模板与泛型编程中处理模板化基类内的名称问题。当编译器遇到模板的定义时,由于特化可能性,无法确定基类函数是否存在。解决方案包括显式指定基类模板、使用作用域解析运算符等,确保所有特化版本支持泛化接口。
最低0.47元/天 解锁文章
1264

被折叠的 条评论
为什么被折叠?



