首页 > 代码库 > Effective C++ Item 41 了解隐式接口和编译期多态
Effective C++ Item 41 了解隐式接口和编译期多态
本文为senlie原创,转载请保留此地址:http://blog.csdn.net/zhengsenlie
经验:class 和 templates 都支持接口和多态。
对 classes 而言接口是显式的,以函数签名为中心。多态则是通过 virtual 函数发生于运行期
对 templates 参数而言,接口是隐式的,奠基于有效表达式。多态则是通过 templates 具体化和函数重载解析(function overloading resolution)发生于编译期。
示例1:显式接口和运行期多态
class Widget{ public: Widget(); virtual ~Widget(); virtual std::size_t size() const; virtual swap(Widget &other); //... }; void doProcessing(Widget &w){ // w的类型被声明为 Widget,所以 w 必须支持 Widget 接口。 Widget 的接口可以在 class Widget 中看到,是显式接口 if(w.size() > 10 && w != someNastyWidget){ //由于 Widget 的 size() 方法被声明为 virtual ,所以 w 对它的调用将出运行期多态 Widget temp(w); temp.normalize(); temp.swap(w); } }
示例2:隐式接口和编译期多态
template<typename T> void doProcessing(T &w){ if(w.size() > 10 && w != someNastyWidget){ T temp(w); temp.normalize(); temp.swap(w); } }
解析:w 必须支持哪一种接口,并不能从哪个地方显式地看出,只能从 template 中执行于 w 身上的操作来决定,是隐式接口。
本例中 w 的类型T好像必须技 size, normalize, swap, copy构造函数, 不等比较。
以不同的 template 参数具体化 function template 会导致调用不同的函数,这便 所谓的编译期多态。
声明:以上内容来自用户投稿及互联网公开渠道收集整理发布,本网站不拥有所有权,未作人工编辑处理,也不承担相关法律责任,若内容有误或涉及侵权可进行投诉: 投诉/举报 工作人员会在5个工作日内联系你,一经查实,本站将立刻删除涉嫌侵权内容。