44 - 继承中的访问级别

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

1. 上一篇遗留的问题

  • 子类是否可以直接访问父类的私有成员?

1.1 思考过程

  • 根据面向对象理论:
    子类拥有父类的一切属性和行为
    ==> 子类 能够直接 访问父类的私有成员
  • 根据 C++:
    外界不能直接访问类的 private 成员
    ==> 子类 不能直接 访问父类的私有成员
  • 矛盾?

1.2 编程实验:继承中的访问级别

#include <iostream>
#include <string>

using namespace std;

class Parent
{
private:
    int mv;
public:
    Parent() {
        mv = 100;
    }
    int value() {
        return mv;
    }
};

class Child : public Parent
{
public:
    int addValue(int v) {
        mv = mv + v;    // 不能访问父类的 private 成员
    }
};

int main()
{   
    return 0;
}

在这里插入图片描述

2. 继承中的访问级别

  • 面向对象中的访问级别不只是 public 和 private
  • 可以定义 protected 访问级别
  • 关键字 protected 的意义:
    • 修饰的成员 不能被外界 直接访问
    • 修饰的成员 可以被子类 直接访问

2.1 编程实验:protected 初体验

#include <iostream>
#include <string>

using namespace std;

class Parent
{
protected: // 不能被外界直接访问,可以被子类直接访问
    int mv;
public:
    Parent() {
        mv = 100;
    }
    int value() {
        return mv;
    }
};

class Child : public Parent
{
public:
    void addValue(int v) {
        mv = mv + v;
    }
};

int main()
{
	Parent p;
	cout << "p.mv = " << p.value() << endl;
	
	p.mv = 1000; // protected 外界不能直接访问
	
    return 0;
}

在这里插入图片描述

#include <iostream>
#include <string>

using namespace std;

class Parent
{
protected: // 不能被外界直接访问,可以被子类直接访问
    int mv;
public:
    Parent() {
        mv = 100;
    }
    int value() {
        return mv;
    }
};

class Child : public Parent
{
public:
    void addValue(int v) {
        mv = mv + v; // protected 可以被子类直接访问
    }
};

int main()
{
	Parent p;
	cout << "p.mv = " << p.value() << endl;
	
	// p.mv = 1000; // protected 外界不能直接访问
	
	Child c;
    cout << "c.mv = " << c.value() << endl;
	
	c.addValue(50);
    cout << "c.mv = " << c.value() << endl;
	
    return 0;
}

在这里插入图片描述

2.2 思考

  • 为什么面向对象中需要 protected?

2.3 定义类时访问级别的选择

在这里插入图片描述

3. 小结

  • 面向对象中的访问级别不只是 public 和 private
  • protected 修饰的成员不能被外界所访问
  • protected 使得子类能够访问父类的成员
  • protected 关键字是为了继承而专门设计的
  • 没有 protected 就无法完成真正意义上的代码复用
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

打赏作者

uuxiang

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

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

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

打赏作者

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

抵扣说明:

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

余额充值