重載覆盖多态与函数隐藏深入解析.docVIP

  1. 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
  2. 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  3. 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
  4. 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
  5. 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们
  6. 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
  7. 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
重載覆盖多态与函数隐藏深入解析

要弄清楚重载、覆盖、多态与函数隐藏之间的复杂且微妙关系之前,我们首先要来回顾一下重载覆盖等基本概念。首先,我们来看一个非常简单的例子,理解一下什么叫函数隐藏hide。 #include iostream using namespace std; class Base{ public: void fun() { cout Base::fun() endl; } }; class Derive : public Base{ public: void fun(int i) cout Derive::fun() endl; } }; int main() { Derive d; //下面一句错误,故屏蔽掉 // d.fun();error C2660: fun : function does not take 0 parameters d.fun(1); Derive *pd =new Derive(); //下面一句错误,故屏蔽掉 // pd-fun();error C2660: fun : function does not take 0 parameters pd-fun(1); delete pd; return 0; } 在不同的非命名空间作用域里的函数不构成重载, 子类和父类是不同的两个作用域。在本例中,两个函数在不同作用域中,故不够成重载,除非这个作用域是命名空间作用域。在这个例子中,函数不是重载overload,也不是覆盖override,而是隐藏hide。 接下来的5个例子具体说明一下什么叫隐藏例1 #include iostream using namespace std; class Basic{ public: void fun(){cout Base::fun() endl;}//overload void fun(int i){cout Base::fun(int i) endl;} //overload }; class Derive :public Basic{ public: void fun2(){cout Derive::fun2() endl;} }; int main() { Derive d; d.fun(); //正确,派生类没有基类中的所有重载函数都会作为候选函数 d.fun(1); //正确,派生类没有基类中的所有重载函数都会作为候选函数 return 0; } 例2 #include iostream using namespace std; class Basic{ public: void fun(){cout Base::fun() endl;}//overload void fun(int i){cout Base::fun(int i) endl;} //overload }; class Derive : public Basic{ public: //新的函数版本,基类所有的重载版本都被屏蔽,在这里,我们称之为函数隐hide //派生类中有基类的同名函数的声明,则基类中的同名函数不会作为候选函数,即使基类有不同的参数表的多个版本的重载函数。 void fun(int i, int j) {cout Derive::fun(int i,int j) endl;} void fun2() {cout Derive::fun2() endl;} };int main() { Derive d; d.fun(1,2); //可自行试验一下,看看d.fun() 或者 d.fun(1)可否? return 0; } 例3 #include iostream using namespace std; class Basic{ public: void fun(){cout Base::fun() endl;}//overload void fun(int i){cout Base::fun(int i) endl;} //overload }; class Derive :public Basic{ public: //覆盖override基类的其中一个函数版本, 同样基类所有的重载版本都被隐hide //派生类中有基类的同名函数

文档评论(0)

fglgf11gf21gI + 关注
实名认证
文档贡献者

该用户很懒,什么也没介绍

1亿VIP精品文档

相关文档