47 - 父子间的冲突 同名覆盖

---- 整理自狄泰软件唐佐林老师课程

1. 思考

  • 子类中是否可以定义父类中的同名成员?
  • 如果可以,如何区分?如果不可以,why?

1.1 编程实验:同名成员变量

#include <iostream>
#include <string>

using namespace std;

class Parent
{
public:
    int mi;
};

class Child : public Parent
{
public:
    int mi;
};

int main()
{
    Child c;
    
    c.mi = 100;    // mi 究竟是子类自定义的,还是从父类继承得到的?
    
    return 0;
}

在这里插入图片描述

1.2 父子间的冲突

  • 子类可以定义父类中的 同名成员
  • 子类中的成员将隐藏父类中的同名成员(同名覆盖
  • 父类中的同名成员 依然存在于子类中
  • 通过 作用域分辨符( : : )访问父类中的同名成员

1.2.1 访问父类中的同名成员

在这里插入图片描述

1.2.2 编程实验:同名成员变量深度分析

#include <iostream>
#include <string>

using namespace std;

class Parent
{
public:
    int mi;
    Parent() {
        cout << "Parent() : " << "&mi = " << &mi << endl;
    }
};

class Child : public Parent
{
public:
    int mi;
    Child() {
        cout << "Child() : " << "&mi  = " << &mi << endl;
    }
};

int main()
{
    Child c;
    
    c.mi = 100;
    c.Parent::mi = 1000;
    
    cout << "&c.mi = " << &c.mi << endl;
    cout << "c.mi  = " << c.mi << endl;
    
    cout << "&c.Parent::mi = " << &c.Parent::mi << endl;
    cout << "c.Parent::mi  = " << c.Parent::mi << endl;
    
    return 0;
}

在这里插入图片描述

2. 再论重载

  • 类中的成员函数可以进行重载
    • 重载函数的本质为多个不同的函数
    • 函数名和参数列表是唯一的标识
    • 函数重载必须发生在同一个作用域中

2.1 问题

  • 子类中定义的函数是否能重载父类中的同名函数?

2.2 编程实验:父子间的函数重载

#include <iostream>
#include <string>

using namespace std;

class Parent
{
public:
    int mi;
    void add(int v) {
		mi += v;
	}
	void add(int a, int b) {
		mi += (a + b);
	}

};

class Child : public Parent
{
public:
    int mi;
    
    // 子类中无 add 成员函数
};

int main()
{
    Child c;
    
    c.mi = 100;
    c.Parent::mi = 1000;
    cout << "c.mi  = " << c.mi << endl;
    cout << "c.Parent::mi  = " << c.Parent::mi << endl;
	
	c.add(1);
	c.add(1, 1);
    cout << "c.mi  = " << c.mi << endl;
    cout << "c.Parent::mi  = " << c.Parent::mi << endl;

    return 0;
}

在这里插入图片描述

#include <iostream>
#include <string>

using namespace std;

class Parent
{
public:
    int mi;
    void add(int v) {
		mi += v;
	}
	void add(int a, int b) {
		mi += (a + b);
	}

};

class Child : public Parent
{
public:
    int mi;
	void add(int x, int y, int z) { // 子类中的 add 会同名覆盖掉父类中的两个 add
									// 子类中的函数将隐藏父类中的同名函数
									// 子类无法重载父类中的成员函数(因为不在同一作用域))
		mi += (x + y + z);
	}
};

int main()
{
    Child c;
    
    c.mi = 100;
    c.Parent::mi = 1000;
    cout << "c.mi  = " << c.mi << endl;
    cout << "c.Parent::mi  = " << c.Parent::mi << endl;
	
	c.add(1);
	c.add(1, 1);
	c.add(1, 1, 1);
    cout << "c.mi  = " << c.mi << endl;
    cout << "c.Parent::mi  = " << c.Parent::mi << endl;

    return 0;
}

在这里插入图片描述

#include <iostream>
#include <string>

using namespace std;

class Parent
{
public:
    int mi;
    void add(int v) {
		mi += v;
	}
	void add(int a, int b) {
		mi += (a + b);
	}

};

class Child : public Parent
{
public:
    int mi;
	void add(int x, int y, int z) { // 子类中的 add 会同名覆盖掉父类中的两个 add
									// 子类中的函数将隐藏父类中的同名函数
									// 子类无法重载父类中的成员函数(因为不在同一作用域))
		mi += (x + y + z);
	}
};

int main()
{
    Child c;
    
    c.mi = 100;
    c.Parent::mi = 1000;
    cout << "c.mi  = " << c.mi << endl;
    cout << "c.Parent::mi  = " << c.Parent::mi << endl;
	cout << endl;
	
	c.Parent::add(10);
	c.Parent::add(10, 10);
	c.add(1, 1, 1);
    cout << "c.mi  = " << c.mi << endl;
    cout << "c.Parent::mi  = " << c.Parent::mi << endl;

    return 0;
}

在这里插入图片描述

2.3 实验结果

  • 子类中的函数将隐藏父类的同名函数(同名覆盖
  • 子类无法重载父类中的成员函数(函数重载必须发生在同一作用域)
  • 使用作用域分辨符访问父类中的同名函数
  • 子类可以定义父类中完全相同的成员函数

3. 小结

  • 子类可以定义父类中的同名成员
  • 子类中的成员将隐藏父类中的同名成员
  • 子类和父类中的函数不能构成重载关系
  • 子类可以定义父类中完全相同的成员函数
  • 使用作用域分辨符访问父类中的同名成员
  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

uuxiang

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值