前面说到C++类的名字自定义要有含义,成员函数名也同样如此。

一个好的程序员除了让自己能看懂代码外,那是能力,也能让别人看懂,那是本事。

我们来看第一个特性:继承!

什么是继承?

小编不说概念性的定义,先举两个例子:

1、你的身体流淌着的是父母的血统。

2、你能学到老师的知识。

能看出什么来?自己体会。

那么在C++中如何继承呢?

我们再创建一个类Teacher.h和Teacher.cpp两个文件。

Teacher.h:

#ifndef      __Teacher_h__
#define __Teacher_h__ class Teachar
{
public:
Teachar();
~Teachar(); public: //公有的属性或成员 int get_KnowLedge()const;              //获取知识 char *get_Name()const;               //获取名字 int get_Age()const;                 //获取年龄 void print_information();             //打印所有的信息
int t_knowledeg; //知识
int t_age; //年龄
char *t_name; //名字 protected: //受保护的属性或成员 private: //私有属性或成员
};

Teacher.cpp

#include "Teacher.h"
#include <iostream>
using namespace std; //构造函数
Teachar::Teachar()
{
this->t_name = "visiousdragon";
this->t_age = 29;
this->t_knowledeg = 100;
} Teachar::~Teachar()
{
} //获取知识
int Teachar::get_KnowLedge() const
{
return this->t_knowledeg;
} //获取名字
char * Teachar::get_Name() const
{
return this->t_name;
} //获取年龄
int Teachar::get_Age() const
{
return this->t_age;
} //获取信息
void Teachar::print_information()
{
cout << this->get_Name() << "\t"
        << this->get_Age() << "\t"
        << this->get_KnowLedge() << endl;
}

创建好了后,我们来继承Teacher类.

打开前面创建的Student.h头文件:

#ifndef  __STUDENT_H__			//if not define 的简写,防止你创建的头文件是否被宏重复定义
#define __STUDENT_H__ #include "Teacher.h" //自定义Student类
class Student
:public Teachar  /*,public Teacher2*/    //这就是继承Teacher的写法,当然也能多继承其他的类,只需要逗号隔开即可。注意:当开发时最好别继承太多的父类,以后你会懂。
{
public:
Student(); //构造函数
~Student(); //析构函数 public: //公有的属性或成员 protected: //受保护的属性或成员 private: //私有属性或成员 };
#endif // ! __STUDENT_H__

既然一切就绪,那我们来看看继承如何实现的。我们Student类内部可是什么都没有写的。

打开主体源文件:

#include <iostream>
#include "Teacher.h"
#include "Student.h"
using namespace std; int main()
{
Student student1; //子类(派生类)继承了Teacher的成员函数,实例化也称创建一个类对象
student1.print_information(); Student *student2 = new Student; //子类(派生类)继承了Teacher的成员函数,实例化也称生成一个类指针对象
student2->print_information(); Teachar *teahcer=&student1; //子类对象引用给父类指针对象,相当于前面学得指针赋值int *p=&number;
teahcer->print_information(); system("pause");
return 0;
}

打印得结果是相同得,那我们就有一个疑惑,什么是继承?通俗得讲:继承(Inheritance)可以理解为一个类从另一个类获取成员变量和成员函数的过程。

有人会问了,子类难道什么都不做吗,只管调用?那怎么可能呢!

子类(派生类)继承了父类(基类),除了继承了父类得成员变量和成员函数外,也可以有自己的成员变量和成员函数。

我们再来看看全新得Student.h头文件内部:

#ifndef  __STUDENT_H__			//if not define 的简写,防止你创建的头文件是否被宏重复定义
#define __STUDENT_H__ #include "Teacher.h" //自定义Student类
class Student
:public Teachar
{
public:
Student(); //构造函数
~Student(); //析构函数 public: //公有的属性或成员
void getTeacherInformation();
char *getTeacherName()const;
int getTeacherAge()const;
int getTeacherKnowledge()const;
protected: //受保护的属性或成员 private: //私有属性或成员
Teachar *teacher;    //将父类指针对象作为Student类的成员变量
};
#endif // ! __STUDENT_H__

再看看全新Studnet.cpp文件内部:


主体源文件:

#include <iostream>
#include "Student.h"
using namespace std; int main()
{
Student student1; //子类(派生类)继承了Teacher的成员函数
student1.getTeacherInformation(); system("pause");
return 0;
}

运行看看,还是可以得到Teacher类内部的数据,不过调用的函数却是Student内部的函数,这就能肯定一点,Student类作为子类时,它可以继承父类的成员变量、函数,也可以拥有自己的成员变量、函数。

有人会奇怪,为什么要在Student构造函数内部实例化Teacher的对象,因为它作为一个Student的成员变量,不实例化(初始化)这个对象,下面的三个函数就无法使用:

...
char *Student::getTeacherName()const
{
return teacher->get_Name();
}
int Student::getTeacherAge()const
{
return teacher->get_Age();
}
int Student::getTeacherKnowledge()const
{
return teacher->get_KnowLedge();
}
...

不信的可以试试,肯定为空,报出异常。

也有人会奇怪,有的地方为什么写this->调用函数,这句this->代表就是当前所在的类指针对象,什么意思?

说白了,它比结构体更简练,每个类都有一个看不见的指针对象,就是它本身,在Student内部使用就代表Student 的指针对象。

当然说到这里不得不提一点,子类继承父类时,执行子类成员函数、构造函数、析构函数,或父类的成员函数、构造函数、析构函数,它都有优先级的。

这里不多说了,可以上网搜搜,也可以在每个函数内部加句代码调试看看。

记住:不是每个人都能把知识讲的非常全面,中间有时也要养成自己动手的能力,多听,多看,多敲,多多总结,努力吧!

C++第四课:类的使用(二)[个人见解]的更多相关文章

  1. 智课雅思词汇---二十四、形容词后缀-al-ial-ar-ary-ic-id-ish-ile-ine-oid-ory

    智课雅思词汇---二十四.形容词后缀-al-ial-ar-ary-ic-id-ish-ile-ine-oid-ory 一.总结 一句话总结: 1.形容词后缀-al? autumnal 英 [ɔː'tʌ ...

  2. 智课雅思词汇---二十四、名词性后缀ary(也是形容词后缀)

    智课雅思词汇---二十四.名词性后缀ary(也是形容词后缀) 一.总结 一句话总结:很多词缀即是名词词缀也是形容词词缀,很多词即是名词也是形容词 1.名词性后缀-tude? 词根词缀:-tude [来 ...

  3. NeHe OpenGL教程 第四十四课:3D光晕

    转自[翻译]NeHe OpenGL 教程 前言 声明,此 NeHe OpenGL教程系列文章由51博客yarin翻译(2010-08-19),本博客为转载并稍加整理与修改.对NeHe的OpenGL管线 ...

  4. 【C语言探险】 第四课的第二部分:串

    内容简单介绍 1.课程大纲 2.第二部分第四课: 字符串 3.第二部分第五课预告: 预处理 课程大纲 我们的课程分为四大部分,每个部分结束后都会有练习题,并会发布答案.还会带大家用C语言编写三个游戏. ...

  5. 【Web探索之旅】第二部分第四课:数据库

    内容简介 1.第二部分第四课:数据库 2.第二部分第五课预告:响应式网站 第二部分第四课:数据库 说到“数据库”,顾名思义,是“数据的仓库”的意思. 所以数据库的一大作用就是储存数据咯. 为什么Web ...

  6. 【C语言探索之旅】 第二部分第四课:字符串

    内容简介 1.课程大纲 2.第二部分第四课: 字符串 3.第二部分第五课预告: 预处理 课程大纲 我们的课程分为四大部分,每一个部分结束后都会有练习题,并会公布答案.还会带大家用C语言编写三个游戏. ...

  7. [Effective Java]第四章 类和接口

    声明:原创作品,转载时请注明文章来自SAP师太技术博客( 博/客/园www.cnblogs.com):www.cnblogs.com/jiangzhengjun,并以超链接形式标明文章原始出处,否则将 ...

  8. 【Linux探索之旅】第二部分第四课:文件操纵,鼓掌之中

    内容简介 1.第二部分第四课:文件操纵,鼓掌之中 2.第二部分第五课预告:用户和权限 文件操纵,鼓掌之中 既然上一课我们学习了Linux中的文件组织方式,那么现在就该是玩弄,啊不,是操纵它们的时候了. ...

  9. 【Linux探索之旅】第一部分第四课:磁盘分区,并完成Ubuntu安装

    内容简介 1.第一部分第四课:磁盘分区,并完成Ubuntu安装 2.第一部分第五课预告:Unity桌面,人生若只如初见 磁盘分区 上一课我们正式开始安装Ubuntu了,但是到了分区的那一步,小编却戛然 ...

随机推荐

  1. Arduino-常用指令

    pinMode(LEDPin,OUTPUT);        //设置引脚模式 参数1      引脚 参数2      OUTPUT  输出:INPUT   输入 用在setup()函数里 digi ...

  2. jquery实现点击页面空白处,弹框消失

    要求:点击1,弹框2显示,点击空白处,弹框2消失 $("#AddDevices"):按钮1 $(".addDeviceBox")弹框2 //点击添加设备弹框 $ ...

  3. BLSTM的训练算法、解码算法以及模型的改进

    摘要 BLSTM解码时,解码器需要等待整个音频到达后才开始解码,因为时间反方向的前向传播需要末尾的历史信息.BLSTM这一延时问题使其不适用与实时语音识别.context-sensitive-chun ...

  4. 开源mall学习

    https://github.com/macrozheng/mall 学习知识点 1.Spring Security 2.@Aspect 3.logstash 4. es crud templete ...

  5. 风火轮SMC532使用

    2018年3月份申请了一个院创,要做一个基于NFC技术的考勤设备,想法是用手机的NFC将学号信息传导考勤机,由考勤机统计缺勤信息,因为自己的拖延症,一直拖到现在.现在一边写毕业论文一边准备院创答辩,又 ...

  6. 面向对象原生JavaScript案例炫彩小球

    面向对象其实对于初学者来说还是比较难以理解的,以前看到一个面试题目 面向对象是什么? 面向对象是一种思想,千万别入坑了: 这次给大家带来的是一个鼠标移动产生小球的案例,不是我不想给大家分享如何去认识面 ...

  7. Debug Dump file

    dump file is a snapshot of the processs memeory. to debug it, we need use its corresponding executiv ...

  8. 快速搭建Docker Registry私有仓库

    前提条件: 服务器已经安装Docker(我的服务器是CentOS 7) 服务器已经安装Docker Compose 满足以上条件时就可以开始搭建了: 1. 生成用户密码文件:(运行下面命令后会在当前目 ...

  9. [Linux]不可重入函数

    一.概述 怎么会有可重入和不可重入. 在多任务系统下,中断可能在任务执行的任何时间发生:如果一个函数的执行期间被中断后,到重新恢复到断点进行执行的过程中,函数所依赖的环境没有发生改变,那么这个函数就是 ...

  10. 可持久化线段树——区间更新hdu4348

    和线段树类似,每个结点也要打lazy标记 但是lazy标记和线段树不一样 具体区别在于可持久化后lazy-tag不用往下传递,而是固定在这个区间并不断累加,变成了这个区间固有的性质(有点像分块的标记了 ...