【C++面向对象】8. 继承

文章目录

  • [【 1. 基本原理 】](#【 1. 基本原理 】)

  • [【 2. 派生类的访问权限 】](#【 2. 派生类的访问权限 】)

  • [【 3. 派生类继承得到的成员的权限 】](#【 3. 派生类继承得到的成员的权限 】)

  • [【 4. 多继承 】](#【 4. 多继承 】)

  • 继承允许我们依据另一个类来定义一个类,这使得创建和维护一个应用程序变得更容易。这样做,也达到了 重用代码功能提高执行时间 的效果。

  • 当创建一个类时,我们不需要重新编写新的数据成员和成员函数,只需指定新建的类继承了一个已有的类的成员即可。这个已有的类称为 基类 (父母),新建的类称为 派生类(新生儿) 。

【 1. 基本原理 】

  • 一个派生类可以从多个基类继承数据和函数。
  • 定义一个派生类,其中,访问修饰符 access-specifier 是 public、protected 或 private 其中的一个,base-class 是之前定义过的某个基类的名称。 如果未使用访问修饰符 access-specifier,则 默认为 private 。形式如下:
cpp 复制代码
class derived-class: access-specifier base-class
  • 实例
cpp 复制代码
#include <iostream>

using namespace std;

// 基类
class Shape 
{
   public:
      void setWidth(int w)
      {
         width = w;
      }
      void setHeight(int h)
      {
         height = h;
      }
   protected:
      int width;
      int height;
};

// 派生类
class Rectangle: public Shape
{
   public:
      int getArea()
      { 
         return (width * height); 
      }
};

int main(void)
{
   Rectangle Rect;

   Rect.setWidth(5);
   Rect.setHeight(7);

   // 输出对象的面积
   cout << "Total area: " << Rect.getArea() << endl;

   return 0;
}

【 2. 派生类的访问权限 】

  • 派生类可以访问基类中所有的非私有成员(public 和 protected 成员)。因此基类成员如果不想被派生类的成员函数访问,则应在基类中声明为 private。
访问 public protected private
同一个类
派生类 ×
外部的类 × ×

【 3. 派生类继承得到的成员的权限 】

  • 根据派生类的继承类型,派生类继承得到的基类的成员的类型也有不同。
  • 通常使用 public 继承,几乎不使用 protected 或 private 继承。
  • private 成员只能被本类成员(类内)和友元访问,不能被派生类访问;protected 成员可以被派生类访问。
基类 成员的访问属性 派生 成员的访问属性
public继承 public → public private → private protected → protected
private 继承 public → private private → private protected → private
protected 继承 public → protected private → private protected → protected

【 4. 多继承 】

  • 多继承即一个子类可以有多个父类,它继承了多个父类的特性。
  • 通过使用一个 类派生列表 可以用来指定派生类的 基类,类派生列表以一个或多个基类命名C++ 类可以从多个类继承成员,其中,继承方式是 public、protected 或 private 其中的一个,用来修饰每个基类,各个基类之间用逗号分隔。语法如下:
cpp 复制代码
class <派生类名>:<继承方式1><基类名1>,<继承方式2><基类名2>,...
{
<派生类类体>
};
  • 实例
cpp 复制代码
#include <iostream>

using namespace std;

// 基类 Shape
class Shape 
{
   public:
      void setWidth(int w)
      {
         width = w;
      }
      void setHeight(int h)
      {
         height = h;
      }
   protected:
      int width;
      int height;
};

// 基类 PaintCost
class PaintCost 
{
   public:
      int getCost(int area)
      {
         return area * 70;
      }
};

// 派生类
class Rectangle: public Shape, public PaintCost
{
   public:
      int getArea()
      { 
         return (width * height); 
      }
};

int main(void)
{
   Rectangle Rect;
   int area;

   Rect.setWidth(5);
   Rect.setHeight(7);

   area = Rect.getArea();

   // 输出对象的面积
   cout << "Total area: " << Rect.getArea() << endl;

   // 输出总花费
   cout << "Total paint cost: $" << Rect.getCost(area) << endl;

   return 0;
}
相关推荐
We་ct2 小时前
LeetCode 5. 最长回文子串:DP + 中心扩展
前端·javascript·算法·leetcode·typescript
JAVA面经实录9175 小时前
Java企业级工程化·终极完整版背诵手册(无遗漏、全覆盖、面试+落地通用)
java·开发语言·面试
王老师青少年编程6 小时前
csp信奥赛C++高频考点专项训练之贪心算法 --【哈夫曼贪心】:合并果子
c++·算法·贪心·csp·信奥赛·哈夫曼贪心·合并果子
周杰伦fans6 小时前
AutoCAD .NET 二次开发:深入理解 EntityJig 的工作原理与正确实现
开发语言·.net
叼烟扛炮6 小时前
C++第二讲:类和对象(上)
数据结构·c++·算法·类和对象·struct·实例化
天疆说6 小时前
【哈密顿力学】深入解读航天器交会最优控制中的Hamilton函数
人工智能·算法·机器学习
wuweijianlove7 小时前
关于算法设计中的代价函数优化与约束求解的技术7
算法
leoufung8 小时前
LeetCode 149: Max Points on a Line - 解题思路详解
算法·leetcode·职场和发展
样例过了就是过了8 小时前
LeetCode热题100 最长公共子序列
c++·算法·leetcode·动态规划
HXDGCL8 小时前
矩形环形导轨:自动化循环线的核心运动单元解析
运维·算法·自动化