继承中的重载,重写及相应隐藏规则
2012-09-27 21:40
323 查看
在C++中的继承中写函数的时候,我们问题会遇到重载,重写,隐藏函数这三大问题。在面向对象的程序设计中,对这三个概念的理解相应重要,否则会出现一些莫明其妙的事件。下面我们来解释下这三个的概念:
重载:即在同一个类中声明相同的函数名,但型参列表的参数类型与及参数的数目不同时,应会发生重载。
示例代码:
重写:即基类中声明virual的函数,子类继承相应的函数,但实现了自己的方法。我们就称为重写(也称覆盖)。即子类调用同名的函数时,调用的是从基类重写的函数,而还在是基类的函数实现。重写是多态产生的机制,把基类中带有virual关键字的函数,在子类中实现自己的版本。这叫重写。注意与隐藏的区别之处。
示例代码:
隐藏:这个在C++中十分特殊,正是这条规则的存在,使得这三个概念的难度一下子就提高了很多。具有有下面有种应用场合。
1.对基类中函数不存在virual关键字,子类继承后,如果再次定义一个同名函数(此时注意不是重载),不管定义的同名函数形参列表类型及个数是否相同,基类的网名函数彻底被隐藏。此时调用子类对象中的函数时,就只能调用子类中定义的函数(注意此函数并不继承自基类的网名函数,并不是所谓的重写)。
代码示例:
重载:即在同一个类中声明相同的函数名,但型参列表的参数类型与及参数的数目不同时,应会发生重载。
示例代码:
class A{ public://函数名相同,形成的重载 void f(){}; void f(int a){}; void f(double b){}; };
重写:即基类中声明virual的函数,子类继承相应的函数,但实现了自己的方法。我们就称为重写(也称覆盖)。即子类调用同名的函数时,调用的是从基类重写的函数,而还在是基类的函数实现。重写是多态产生的机制,把基类中带有virual关键字的函数,在子类中实现自己的版本。这叫重写。注意与隐藏的区别之处。
示例代码:
class A{ public: virtual void print(){ cout<<"A print()"<<endl; } }; class B : public A{ public: virtual void print(){//此时就是重写,实现自己的处理 cout<<"B print()"<<endl; } };此时,调用B对象的print方法时,就会执行B对象改造后的print函数版本。
隐藏:这个在C++中十分特殊,正是这条规则的存在,使得这三个概念的难度一下子就提高了很多。具有有下面有种应用场合。
1.对基类中函数不存在virual关键字,子类继承后,如果再次定义一个同名函数(此时注意不是重载),不管定义的同名函数形参列表类型及个数是否相同,基类的网名函数彻底被隐藏。此时调用子类对象中的函数时,就只能调用子类中定义的函数(注意此函数并不继承自基类的网名函数,并不是所谓的重写)。
class A{ public: void print(string s){ cout<<"A print()"<<endl; } }; class B : public A{ public: void print(int x){//此时会发生隐藏,没有重载 cout<<"B print(int a)"<<endl; } }; int main(){ B b; b.print("hello");//error,参数类型错误。此时调用的是print(int x)函数 b.print(1); //right,此时基类同名函数被隐藏 }下面的是基类带有virual关键字代码示例,此时子类重写了基类中继承的virual同名函数,然后有又定义也自己和基类同名但参数类型不同的函数。
代码示例:
class A{ public: virtual void print(string s){ cout<<"A print()"<<endl; } }; class B : public A{ public: virtual void print(string s){//函数重写 cout<<"B print(string s)"<<endl; } void print(int x){//此时会发生隐藏,没有重载 cout<<"B print(int a)"<<endl; } }; int main(){ B b; b.print("hello"); //right,->B print(string s) //被重写的函数没有被隐藏 b.print(1); //right, ->B print(int a) }注意:此时调用的b.print("hello")正确执行。但如果子类没有重写基类当中的同名virual函数。则此时b.print("hello")不能成功。发现所谓的隐藏现象。凡是基类中virual函数,没有在子类中重写的,而子类有定义也自己的同名不同参数类型的函数时,所有从基类继承的同名函数都被隐藏,只有自己定义的函数可见。看下面的代码示例:就会出现错误情况
class A{ public: virtual void print(string s){ cout<<"A print()"<<endl; } }; class B : public A{ public: //virtual void print(string s){//函数重写 // cout<<"B print(string s)"<<endl; //}注释后,就出现隐藏现象了,一定要留意此规则 void print(int x){//此时会发生隐藏,没有重载 cout<<"B print(int a)"<<endl; } }; int main(){ B b; b.print("hello"); //error,此时b类中没有print(string s)类型的函数,被我们定义的同名函数隐藏了 b.print(1); //right, ->B print(int a) }
相关文章推荐
- 继承中的重载,重写及相应隐藏规则开启的时机
- c#重写,覆盖,隐藏,重载,继承
- java基础01 从Java的继承谈 重载、重写(覆盖)、隐藏
- C++ 继承真正在做的事系列【重载,重写/覆盖,隐藏】
- 1.为什么需要继承?如何继承?继承到什么? 2.方法的重载与重写的区别 3.类型的自动转换和强制转换 4.子类特有的方法的调用规则 5.子类重写的方法的调用规则 6.多态的理解 7.面向对象的三大特征
- 继承过程中重载VS重写---(重写规则)
- 5、面向对象以及winform的简单运用(方法重载、隐藏、重写与虚方法)
- 重载(overload),覆盖/重写(override),隐藏(hide)
- java总的重载(overload)、重写或覆盖(override)和隐藏分析;
- C++_重载、重写(覆盖)和隐藏的区别:
- C++成员函数的重载,继承,覆盖和隐藏
- [转]Java中继承、多态、重载和重写介绍
- 重载,重写(覆盖),隐藏
- 谈谈C++继承中的重载,覆盖和隐藏
- Java小记之方法重写与继承中的构造方法的规则
- Java中的重载、重写和隐藏
- 继承、多态、重载和重写
- 谈谈C++继承中的重载,覆盖和隐藏
- C+=重载、重写和隐藏的区别以及实例分析
- Objective-c 类的继承 方法重写 方法重载