代码来源: 传智播客
我认为这个代码完美展示了重载、重写与重定义区别。
另外,还有在重写后的子类同名函数会对父类同名函数产生覆盖问题。(我认为这个细节问题的原因在于: 你这样调用基于的出发点是函数重载, 但是不要忘记重载前提是只能发生在同一个类中。所以子类同名函数会对父类函数产生覆盖。。)
#include<iostream>
using namespace std;
//重写 重载 重定义
//重写发生在2个类之间 (重写与重定义)
//重载必须在一个类之间
//重写分为2类
//1 虚函数重写 将发生多态
//2 非虚函数重写 (重定义)
class Parent
{
//这个三个函数都是重载关系
public:
void abc()
{
printf("abc");
}
virtual void func()
{
cout << "func() do..." << endl;
}
virtual void func(int i)
{
cout << "func() do..." << i << endl;
}
virtual void func(int i, int j)
{
cout << "func() do..." << i << " " << j << endl;
}
virtual void func(int i, int j, int m, int n)
{
cout << "func() do..." << i << " " << j << endl;
}
protected:
private:
};
class Child : public Parent
{
public:
void abc()
{
printf("child abc");
}
/*
void abc(int a)
{
printf("child abc");
}
*/
virtual void func(int i, int j)
{
cout << "func(int i, int j) do..." << i << " " << j << endl;
}
virtual void func(int i, int j, int k)
{
cout << "func(int i, int j) do.." << endl;
}
protected:
private:
};
//重载重写和重定义
void main()
{
//: error C2661: “Child::func”: 没有重载函数接受 0 个参数
/*Parent *p=NULL;
Child c1;
p = &c1;*/
c1.func();
//子类无法重载父类的函数,父类同名函数将被名称覆盖
//p->func();
//c1.func(1,1);
//1 C++编译器 看到func名字 ,因子类中func名字已经存在了(名称覆盖).所以c++编译器不会去找父类的4个参数的func函数
//2 c++编译器只会在子类中,查找func函数,找到了两个func,一个是2个参数的,一个是3个参数的.
//3 C++编译器开始报错..... error C2661: “Child::func”: 没有重载函数接受 4 个参数
//4 若想调用父类的func,只能加上父类的域名..这样去调用..
c1.func(1, 3, 4, 5);
//c1.func();
//func函数的名字,在子类中发生了名称覆盖;子类的函数的名字,占用了父类的函数的名字的位置
//因为子类中已经有了func名字的重载形式。。。。
//编译器开始在子类中找func函数。。。。但是没有0个参数的func函数
cout << "hello..." << endl;
system("pause");
return;
}