#include <cstdio>
#include <cstdlib> class Base
{
public:
#pragma region MyRegion1 //函数重载(overload)
//step1:在同一个类中
//step2:函数名相同;
//step3:参数不同;
//step4:virtual 关键字可有可无
void overload_fun(int x,int y)
{
printf("Base::overload_fun(int x,int y) %d %d\n",x,y);
}
void overload_fun(int x)
{
printf("Base::overload_fun(int x) %d\n",x);
}
//end #pragma endregion #pragma region MyRegion2 //函数覆盖(override):指派生类函数覆盖基类函数
//step1:不同的范围(分别位于派生类与基类);
//step2:函数名相同;
//step3:参数相同;
//step4:基类函数必须有virtual 关键字。
virtual void override_fun(int x,int y,int z)
{
printf("Base::override_fun() x=%d y=%d z=%d\n",x,y,z);
}
//end #pragma endregion #pragma region MyRegion3 //函数重写(overwrite):指派生类的函数屏蔽了与其同名的基类函数
//第一种
//step1:函数名与基类相同;
//step2:参数不同;
//step3:无论有无virtual 基类函数将被隐藏。
void overwrite_fun1(int x,int y)
{
printf("Base::overwrite_fun1(int x,int y) x=%d y=%d\n",x,y);
} //函数重写(overwrite)第二种
//step1:函数名与基类相同;
//step2:参数相同;
//step3:无virtual 基类函数将被隐藏。
//注意区别于函数覆盖(override)
void overwrite_fun2(int x,int y)
{
printf("Base::overwrite_fun2(int x,int y) x=%d y=%d\n",x,y);
}
//end #pragma endregion
} ; class Derived : public Base
{
public:
//函数覆盖(override)
virtual void override_fun(int x,int y,int z) override{
printf("Derived::override_fun() x=%d y=%d z=%d\n",x,y,z);
} //函数重写 第一种
void overwrite_fun1(int x)
{
printf("Derived::overwrite_fun1(int x) x=%d\n",x);
}
//函数重写 第二种
void overwrite_fun2(int x,int y)
{
printf("Derived::overwrite_fun2(int x,int y) x=%d y=%d\n",x,y);
}
} ;
int main(int agrc,char* agrv[])
{
printf("=============================================\n");
//测试函数覆盖
Base* pBase = new Derived();
pBase->override_fun(1,2,3);
printf("=============================================\n"); printf("=============================================\n");
//测试函数重写第一种情况,参数不同
Derived der;
der.overwrite_fun1(1);
//基类同名函数被隐藏
//调用基类同名函数
der.Base::overwrite_fun1(1,2);
printf("=============================================\n"); printf("=============================================\n");
//测试函数重写第二种情况
der.overwrite_fun2(1,2);
//基类同名函数被隐藏
//调用基类同名函数
der.Base::overwrite_fun2(1,2);
printf("=============================================\n"); system("PAUSE");
return 0;
}

运行结果:

补充说明,网上摘录:

Overload(重载):在C++程序中,可以将语义、功能相似的几个函数用同一个名字表示,但参数或返回值不同(包括类型、顺序不同),即函数重载。
(1)相同的范围(在同一个类中);
(2)函数名字相同;
(3)参数不同;
(4)virtual 关键字可有可无。

Override(覆盖):是指派生类函数覆盖基类函数,特征是:
(1)不同的范围(分别位于派生类与基类);
(2)函数名字相同;
(3)参数相同;
(4)基类函数必须有virtual 关键字。

Overwrite(重写):是指派生类的函数屏蔽了与其同名的基类函数,规则如下:
(1)如果派生类的函数与基类的函数同名,但是参数不同。此时,不论有无virtual关键字,基类的函数将被隐藏(注意别与重载混淆)。

(2)如果派生类的函数与基类的函数同名,并且参数也相同,但是基类函数没有virtual关键字。此时,基类的函数被隐藏(注意别与覆盖混淆)。

C++中overload(重载),override(覆盖),overwrite(重写/覆写)的区别的更多相关文章

  1. C++中overload 、override、overwrite 之间的区别

    Overload(重载):在C++程序中,可以将语义.功能相似的几个函数用同一个名字表示,但参数或返回值不同(包括类型.顺序不同),即函数重载.(1)相同的范围(在同一个类中):(2)函数名字相同:( ...

  2. JAVA中继承时方法的重载(overload)与重写/覆写(override)

    JAVA继承时方法的重载(overload)与重写/覆写(override) 重载-Override 函数的方法参数个数或类型不一致,称为方法的重载. 从含义上说,只要求参数的个数或参数的类型不一致就 ...

  3. C++中的Overload、Override和Overwrite

    在C++语言中有一组基础的概念一直都容易混淆:Overload.Override和Overwrite分别表示什么意思?下面把这三个概念整理一下: 1. Overload(重载) 重载的概念最好理解,在 ...

  4. c++中的隐藏、重载、覆盖(重写)

    转自c++中的隐藏.重载.覆盖(重写) 1 重载与覆盖 成员函数被重载的特征: (1)相同的范围(在同一个类中): (2)函数名字相同: (3)参数不同: (4)virtual关键字可有可无. 覆盖是 ...

  5. Delphi中静态方法重载还是覆盖的讨论

    Delphi中静态方法重载还是覆盖的讨论 新人学习Delphi的时候,容易搞不懂的一个问题,当子类方法和基类方法同名,并且参数也一样的时候,叫做什么呢?是覆盖,还是重载呢? 答案是隐藏父类方法. 一般 ...

  6. C++中的重载、覆盖、隐藏

    前几天面试时被问及C++中的覆盖.隐藏,概念基本答不上来,只答了怎么用指针实现多态,也还有遗漏.最终不欢而散.回来后在网上查找学习了一番,做了这个总结.其中部分文字借用了别人的博客,望不要见怪.引用的 ...

  7. Overload and Override without Overwrite - Java

    Override(覆盖/覆写): 子类Override父类中的函数(方法).Overload(重载): 同一个类中包含多个同名的函数(方法), 但各个函数的参数列表不同. Override和Overl ...

  8. C++中的重载隐藏覆盖&&JAVA中的重载覆盖&&多态

    class 类继承默认是private, struct 默认继承是public C++中的隐藏: 只要派生类中出现和基类一样的函数名,基类中的函数就会被派生类中的函数给隐藏(如果派生类和基类中的函数名 ...

  9. 【转】c++重载、覆盖、隐藏——理不清的区别

    原文网址:http://blog.sina.com.cn/s/blog_492d601f0100jqqm.html 再次把林锐博士的<高质量c++编程指南>翻出来看的时候,再一次的觉得这是 ...

随机推荐

  1. Ollydbg

    1.用来查看dll文件的信息,取代现在使用的exescope;

  2. day3_字典

    一.说明 字典的每个键值(key=>value)对用冒号(:)分割,每个对之间用逗号(,)分割,整个字典包括在花括号({})中 ,格式如下所示: dict = {key1:value1,key2 ...

  3. 图->连通性->最小生成树(普里姆算法)

    文字描述 用连通网来表示n个城市及n个城市间可能设置的通信线路,其中网的顶点表示城市,边表示两城市之间的线路,赋于边的权值表示相应的代价.对于n个定点的连通网可以建立许多不同的生成树,每一棵生成树都可 ...

  4. 20165317 Linux安装及学习

    Linux安装及学习 一.Linux的安装 我通过virtualbox和ubuntu官网下载了virtualbox5.2.6和ubuntu17.04版本. 在操作过程中,我基本是按照老师的步骤进行的, ...

  5. 如何使用 window api 转换字符集?(std::string与std::wstring的相互转换)

    //宽字符转多字节 std::string W2A(const std::wstring& utf8) { int buffSize = WideCharToMultiByte(CP_ACP, ...

  6. 洛谷P4064 加法 [JXOI2017] 贪心

    正解:贪心 解题报告: 传送门! 首先最小值最大显然考虑二分?然后就二分一个值mid,从左往右考虑,对于小于等于mid的点显然可以求出这个点至少要加几次,然后找到覆盖这个点的右端点max的区间区间加上 ...

  7. MySQL加锁处理分析(转)

    add by zhj: 非常棒的一篇文章,是我见过的讲加锁最棒最详细的文章了.之前听过网易的<MySQL微专业>,里面的课程讲的也很好,但锁这块讲的跟 这篇文章相比,还是有差距的.网易&l ...

  8. es分词器

    1.默认的分词器 standard standard tokenizer:以单词边界进行切分standard token filter:什么都不做lowercase token filter:将所有字 ...

  9. CSS学习(二)

    <!DOCTYPE html> <html> <head> <meta charset="{CHARSET}"> <title ...

  10. gitlab访问用户安装的postgresql数据库

    1.先将gitlab默认安装的postgresql的数据库中的数据,导入到用户安装的postgresql数据 用Navicat迁移数据.函数不用迁移. 2.配置gitlab对postgresql数据库 ...