c++-纯虚函数和抽象类
纯虚函数和抽象类
- C面向接口编程和C多态
- 函数类型语法基础
- 函数指针做函数参数(回调函数)思想剖析
- 函数指针做函数参数两种用法(正向调用、反向调用)
- 纯虚函数 抽象类
- 抽象类基本概念
- 抽象类在多继承中的应用
- 面向抽象类编程案例强化
- C面向接口编程和C多态
#define _CRT_SECURE_NO_WARNINGS
#include <iostream>
using namespace std;
//图形类
//如果说一个类 拥有一个纯虚函数
//就称这个类是一个抽象类。
//不管这个类中有没有成员属性,只要这个类有纯虚函数,就是一个抽象类, 抽象类就是不能够实例化的。
class Shape
{
public:
//求图形面积的方法
//表示图形类声明一个方法getArea(),它是一个纯虚函数,没有函数的实现。
virtual double getArea() = 0;
};
//三角形
class Tri :public Shape
{
public:
Tri(int a, int h)
{
this->a = a;
this->h = h;
}
virtual double getArea() {
cout << "三角形求面价" << endl;
return 0.5*a*h;
}
private:
int a;
int h;
};
//正方形:
//如果说一个普通类,继承拥有纯虚函数的类,如果说不重写纯虚函数,依然是一个抽象类。
//依然不能被实例化, 如果想实例化, 必须要重写这个父类中所有纯虚函数
class Rect : public Shape
{
public:
Rect(int a) {
this->a = a;
}
virtual double getArea() {
cout << "正方形求面积" << endl;
return a*a;
}
private:
int a;//正方形边长
};
class Circle :public Shape
{
public:
Circle(int r)
{
this->r = r;
}
virtual double getArea()
{
cout << "圆形求面积" << endl;
return 3.14*r * 4;
}
private:
int r;
};
//面向抽象类写一个架构函数
void printArea(Shape *sp)
{
sp->getArea();
}
//业务层 面向的抽象类编程
int main(void)
{
//main 中所有使用的变量类型 都是 抽象类Shape的类型。
Shape *sp1 = new Rect(10);
//sp1->getArea();
Shape *sp2 = new Circle(20);
//sp2->getArea();
Shape *sp3 = new Tri(10, 20);
//sp3->getArea();
printArea(sp1);
printArea(sp2);
printArea(sp3);
return 0;
}
上一个知识的小练习
#define _CRT_SECURE_NO_WARNINGS
#include <iostream>
using namespace std;
//大哥的虚衔
class BigBrother
{
public:
//会打人。
virtual void fightPeople() = 0;
};
//东方不败
class EastNeverLose :public BigBrother
{
public:
virtual void fightPeople() {
cout << "使用了葵花宝典区打人" << endl;
}
};
//无崖子
class Wuyazi :public BigBrother
{
public:
virtual void fightPeople() {
cout << "使用北冥神功打人" << endl;
}
};
//boss
int main(void)
{
BigBrother *bigbrother = new Wuyazi;
//大哥你给我去打人。
bigbrother->fightPeople();
delete bigbrother;
return 0;
}
纯虚函数和多继承
#define _CRT_SECURE_NO_WARNINGS
#include <iostream>
using namespace std;
//接口1
class Interface1
{
public:
virtual void func1(int a, int b) = 0;
virtual void func3(int a, int b) = 0;
};
//接口2
class Interface2
{
public:
virtual void func2(int a) = 0;
};
class Child :public Interface1, public Interface2
{
public:
virtual void func1(int a, int b)
{
cout << "func1" << endl;
}
virtual void func3(int a, int b) {
cout << "func3" << endl;
}
virtual void func2(int a)
{
cout << "func2 " << endl;
}
};
int main(void)
{
Interface1 *if1 = new Child;
if1->func1(10, 20);
if1->func3(100, 200);
Interface2 *if2 = new Child;
if2->func2(10);
return 0;
}
电脑组装--小练习
#define _CRT_SECURE_NO_WARNINGS
#include <iostream>
using namespace std;
//-------- 抽象层---------
//抽象CPU类
class CPU
{
public:
CPU();
virtual void caculate() = 0;
};
//抽象的card类
class Card
{
public:
virtual void display() = 0;
};
//抽象的内存类
class Memory
{
public:
virtual void storage() = 0;
};
//架构类
class Computer
{
public:
Computer(CPU *cpu, Card *card, Memory *mem)
{
this->cpu = cpu;
this->card = card;
this->mem = mem;
}
void work()
{
this->cpu->caculate();
this->card->display();
this->mem->storage();
}
~Computer() {
if (this->cpu != NULL) {
delete this->cpu;
}
if (this->card != NULL) {
delete this->card;
}
if (this->mem != NULL) {
delete this->mem;
}
}
private:
CPU* cpu;
Card*card;
Memory *mem;
};
// --------------------------
//-----------实现层----------
//具体的IntelCPU
class IntelCPU :public CPU
{
public:
virtual void caculate() {
cout << "Intel CPU开始计算了" << endl;
}
};
class IntelCard :public Card
{
public:
virtual void display() {
cout << "Intel Card开始显示了" << endl;
}
};
class IntelMem :public Memory {
public:
virtual void storage() {
cout << "Intel mem开始存储了" << endl;
}
};
class NvidiaCard :public Card
{
public:
virtual void display() {
cout << "Nvidia 显卡开始显示了" << endl;
}
};
class KingstonMem :public Memory {
public:
virtual void storage() {
cout << "KingstonMem 开始存储了" << endl;
}
};
//--------------------------
//--------业务层-------------------
int main(void)
{
//1 组装第一台intel系列的电脑
#if 0
CPU *intelCpu = new IntelCPU;
Card *intelCard = new IntelCard;
Memory *intelMem = new IntelMem;
Computer *com1 = new Computer(intelCpu, intelCard, intelMem);
com1->work();
Card *nCard = new NvidiaCard;
Memory* kMem = new KingstonMem;
Computer *com2 = new Computer(intelCpu, nCard, kMem);
com2->work();
delete intelCpu;
#endif
Computer *com1 = new Computer(new IntelCPU, new IntelCard, new IntelMem);
com1->work();
delete com1;
return 0;
}
c++-纯虚函数和抽象类的更多相关文章
- C++学习基础十二——纯虚函数与抽象类
一.C++中纯虚函数与抽象类: 1.含有一个或多个纯虚函数的类成为抽象类,注意此处是纯虚函数,而不是虚函数. 2.如果一个子类继承抽象类,则必须实现父类中的纯虚函数,否则该类也为抽象类. 3.如果一个 ...
- C++基础(纯虚函数与抽象类)
C++基础之纯虚函数与抽象类 引言 纯虚函数在C++编程中的地位很重要,其关联到了设计模式中"接口"的概念. 语法 纯虚函数的语法: 1. 将成员函数声明为virtual 2. ...
- C++:纯虚函数与抽象类
5.4.3 纯虚函数和抽象类 纯虚函数是一个在基类中说明的虚函数,它在该基类中没有定义,但是要求在派生类中根据需要对它进行定义,或仍然说明为纯虚函数. 声明纯虚函数的一般格式是: virtual 函数 ...
- c++,纯虚函数与抽象类
1.纯虚函数的定义: (1)虚函数被“初始化”为0的函数.声明纯虚函数的一般形式是virtual 函数类型 函数名(参数表列) =0;(2)纯虚函数没有函数体:(3)最后面的“=0”并不表示函数返回值 ...
- C++复习:纯虚函数和抽象类
纯虚函数和抽象类 1基本概念 2抽象类案例 3抽象类在多继承中的应用 C++中没有Java中的接口概念,抽象类可以模拟Java中的接口类.(接口和协议) 3.1有关多继承的说明 工程上的多继承 被 ...
- 简单地说, cpp中的纯虚函数就是抽象类的具体实现
简单地说, cpp中的纯虚函数就是抽象类的具体实现.包含了纯虚函数的类就是抽象类.
- C++基础 (7) 第七天 多态的原理 纯虚函数和抽象类 依赖倒置原则
1 昨日回顾 2 多态的原理 1 要有继承 2 要有子类重写父类的虚函数 3 父类指针(或者引用)指向子类对象 (动态联编 虚函数表 3 证明vptr指针的存在 4 vptr指针在构造父类的时候是分步 ...
- C++开发系列-纯虚函数和抽象类
概念 纯虚函数和抽象类 纯虚函数是一个在基类中说明的虚函数,在基类中没有定义,要求任何派生类都实现该函数. 纯虚函数为各派生类提供了一个公共界面(接口的封装和设计.软件的模块功能的划分) 纯虚函数说明 ...
- cc32b_demo-32dk2j_cpp_纯虚函数与抽象类2-txwtech
cc32b_demo-32dk2j_cpp_纯虚函数与抽象类2-txwtech //纯虚函数是用来继承用的//纯虚函数//抽象类-抽象数据类型//*任何包含一个或者多个纯虚函数的类都是抽象类//*不要 ...
随机推荐
- springboot+logback日志输出企业实践(下)
目录 1.引言 2. 输出 logback 状态数据 3. logback 异步输出日志 3.1 异步输出配置 3.2 异步输出原理 4. springboot 多环境下 logback 配置 5. ...
- Java基础面试题及答案(四)
反射 57. 什么是反射? 反射主要是指程序可以访问.检测和修改它本身状态或行为的一种能力 Java反射: 在Java运行时环境中,对于任意一个类,能否知道这个类有哪些属性和方法?对于任意一个对象,能 ...
- Spring(Bean)6
生命周期构造 --->set--->Bean init前后执行 (新创建 类) public class MyBeanPostProcesser implements BeanPostPr ...
- JS 输出指定范围内的随机数
/* 自定义函数 */ function GetRandomNum(Min,Max){ var Range = Max - Min; var Rand = Math.random(); return( ...
- phpStudy搭建PHP服务器
目录 1 下载 2 安装 3 新建站点 4 配置host phpStudy是一个PHP调试环境的程序集成包. 该程序包集成最新的 Apache+Nginx+LightTPD PHP MySQL+php ...
- PyCharm 2019.3激活破解教程(永久)
2019.12.02 jetbrains公司发布了Python的最强编辑器PyCharm 2019.3版本.本次大版本主要对Jupyter notebooks .MongoDB.Python3.8功能 ...
- 这货到底还是不是垃圾?【垃圾回收GC算法JVM篇四】
目录 1.判断对象是否存活的JVM两种计数算法 2.垃圾收集算法 3.垃圾回收算法小结 垃圾收集 Garbage Collection 通常被称为"GC", 在jvm 中,程序计数 ...
- 【IoT平台北向API调用】使用Postman调用Https接口
1. Download and install postman https://www.getpostman.com/ Version:the version I download is Postma ...
- 输入URL到页面渲染
输入网址回车或者刷新页面到页面传染出来的整个流程 DNS 解析 HTTP三次握手 -> TCP/IP连接 浏览器发送请求 服务器返回请求的文件 (html) 浏览器渲染 1. DNS 解析 查找 ...
- AutoLayout的那些事儿
转自:http://www.cocoachina.com/ios/20160530/16522.html 本文投稿文章,作者:MangoMade(简书) AutoLayout非常强大也非常易用,可读性 ...