成员函数被重载的特征:
(1)相同的范围(在同一个类中);
(2)函数名字相同;
(3)参数不同;
(4)virtual关键字可有可无。
覆盖是指派生类函数覆盖基类函数,特征是:
(1)不同的范围(分别位于派生类与基类);
(2)函数名字相同;
(3)参数相同;
(4)基类函数必须有virtual关键字。
“隐藏”是指派生类的函数屏蔽了与其同名的基类函数,规则如下:
(1)如果派生类的函数与基类的函数同名,但是参数不同。此时,不论有无virtual关键字,基类的函数将被隐藏(注意别与重载混淆)。
(2)如果派生类的函数与基类的函数同名,并且参数也相同,但是基类函数没有virtual关键字。此时,基类的函数被隐藏(注意别与覆盖混淆)。
现在我分析一下它们在内存的存储情况:
1、函数的重载与函数的覆盖不同,重载不是子类对父类的同名函数的重新定义,而是类对自身已有的同名函数的重新定义.
2、函数的覆盖中不仅覆盖了父类的函数,同进也把父类的同名函数在子类的内存空间清除掉;但在子类变量的隐藏中屏蔽了父类的变量,可是父类的变量在子类中仍然占有一下的内存空间。
覆盖就是虚函数的覆盖。没有覆盖,虚函数就没有意义了。虚函数只是用virtual说明的成员函数,覆盖才是其真正的目的。
隐藏不一定有什么特殊的用处,只是一种现象。比如两个窗口类A、B,A是B的基类,定义了Create方法,B也定义了Create方法(这样的主要目的 是统一接口名称),这时就出现了隐藏。两个类的Create方法参数可以不一样,做的事情也可以完全不同,也不可能声明为virtual,这就是隐藏的例 子了。
(1)相同的范围(在同一个类中);
(2)函数名字相同;
(3)参数不同;
(4)virtual关键字可有可无。
覆盖是指派生类函数覆盖基类函数,特征是:
(1)不同的范围(分别位于派生类与基类);
(2)函数名字相同;
(3)参数相同;
(4)基类函数必须有virtual关键字。
“隐藏”是指派生类的函数屏蔽了与其同名的基类函数,规则如下:
(1)如果派生类的函数与基类的函数同名,但是参数不同。此时,不论有无virtual关键字,基类的函数将被隐藏(注意别与重载混淆)。
(2)如果派生类的函数与基类的函数同名,并且参数也相同,但是基类函数没有virtual关键字。此时,基类的函数被隐藏(注意别与覆盖混淆)。
现在我分析一下它们在内存的存储情况:
1、函数的重载与函数的覆盖不同,重载不是子类对父类的同名函数的重新定义,而是类对自身已有的同名函数的重新定义.
2、函数的覆盖中不仅覆盖了父类的函数,同进也把父类的同名函数在子类的内存空间清除掉;但在子类变量的隐藏中屏蔽了父类的变量,可是父类的变量在子类中仍然占有一下的内存空间。
覆盖就是虚函数的覆盖。没有覆盖,虚函数就没有意义了。虚函数只是用virtual说明的成员函数,覆盖才是其真正的目的。
隐藏不一定有什么特殊的用处,只是一种现象。比如两个窗口类A、B,A是B的基类,定义了Create方法,B也定义了Create方法(这样的主要目的 是统一接口名称),这时就出现了隐藏。两个类的Create方法参数可以不一样,做的事情也可以完全不同,也不可能声明为virtual,这就是隐藏的例 子了。
![](http://c.services.spaces.live.com/CollectionWebService/c.gif?space=javaxgm&page=RSS%3A+overload+++%E9%87%8D%E8%BD%BD++VS++override++%E8%A6%86%E7%9B%96&referrer=)
![](https://i-blog.csdnimg.cn/blog_migrate/bb955c70b7ac529889dbd40670c716ca.gif)