- 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
 - 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
 - 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
 - 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
 - 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们。
 - 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
 - 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
 
                        查看更多
                        
                    
                x.f()的解决方法 方法一:C类的成员在引用f 时说明是A的f 还是B的f。如:x.A::f();    或 x.B::f();    其缺陷是对C的用户不利。C用户必须知道自己是从哪些基类派生出来的。 方法二:在C类声明中指出基类名。如在C中可声明:void ha()  {A::f(); }                                void hb() { B::f();} 二义性---cont. 如果一个派生类从多个基类派生,而这些基类又有公共的基类,则对该基类中声明的名字进行访问时,可能会产生二义性。这个问题由虚基类来解决。 二义性---cont. 如: Class B{ public: int b;}; Class B1: public B{ private: int b1;}; Class B2: public B{ private: int b2;}; Class C: public B1, public B2    {public: int f();      private: int d;};  定义: C  c; 下面对b的访问是有二义性的: c.b c.B::b 下面对b的访问是正确的: c.B1::b b.B2::b 二义性实例 class A{public:   void fun(){coutA:fun()endl; }     }; class B1:public A        {public:   void fun1(){coutB1:fun1()endl; }   }; class B2:public A        {public:    void fun1(){coutB2:fun1()endl; }    }; class D:public B1,public B2   {}; void main() { D obj;   //obj.fun1();    //不可以执行各有fun1()函数)   obj.B1::fun1();   obj.B2::fun1();   //obj.fun();      //不可以执行   //obj.A::fun();   //不可以执行:二义性   obj.B1::fun();    //无二义性:可以执行  }  虚基类 用途:当一个派生类是从多个基类派生,而这些基类又有一个公共的基类。则在这个派生类中访问公共基类中的成员时会有二义性问题。如上例中的B, B1, B2和C,他们的派生关系是: B B B1 B2 C 如果B只有一个拷贝的话,那么在C中对B成员的访问就不会有二义性。 虚基类的概念 使公共的基类只产生一个拷贝。 虚基类的定义用关键词virtual。如:    Class B{ public: int b;};    Class B1: virtual public B{ private: int b1;};    Class B2: virtual public B{ private: int b2;};    Class C: public B1, public B2     {public: int f();      private: int d;};    这样B1, B2公用了一个B的拷贝,    对B成员的引用就不会产生二义性。 B B1 B2 C 虚基类的初始化 保证虚基类对象只被初始化一次。 虚基类的构造由最终的类的构造函数负责。 例如,在构造C的对象时,由C的构造函数负责调用B的构造函数,而不是由B1、B2来调用。 构造次序:先执行B的构造函数,再执行B1、B2的构造函数,最后执行C的构造函数。 析构次序与构造次序相反。 虚基类的初始化实例 #include iostream.h class B{ int a;    public: B(int sa)  {a=sa; coutconstructing B\n;}}; class B1:virtual public B{  int b; 	public: B1(int sa, int sb):B(sa) 	         {b=sb;  coutconstructing B1\n;}	}; class B2:virtual public B{  int c; 	public: B2(int sa, int sb):B(sa) 	          {c=sb;   coutconstructing B2\n;}}; class C: public B1, public B2{   int d; 	public: C(int sa, int sb, int sc, int sd):                    B(sa), B1(sa,
                
原创力文档
                        

文档评论(0)