C++ 学习之旅(16)——虚函数与纯虚函数virtual

关于虚函数的概念讲解,可以看这篇文章:

https://blog.csdn.net/siwuxie095/article/details/71159414

以下用例子进行实际说明:

#include <iostream> 
using namespace std;class Shape {
public:int width, height;Shape(int a = 0, int b = 0){width = a;height = b;}void area(){cout << "Parent class has no area" << endl;}
};class Rectangle : public Shape {
public:Rectangle(int a = 0, int b = 0) :Shape(a, b) { }void area(){cout << "Rectangle class area :" << width * height << endl;}
};class Triangle : public Shape {
public:Triangle(int a = 0, int b = 0) :Shape(a, b) { }void area(){cout << "Triangle class area :" << width * height / 2 << endl;}
};int main()
{Shape* sha1 = new Shape(10, 5);Rectangle* rec = new Rectangle(10, 5);Triangle*  tri = new Triangle(10, 5);sha1->area();rec->area();tri->area();cin.get();return 0;
}

我们有形状类Shape,它有两个子类:Rectangle矩形类和Triangle三角形类。

利用多态的思想,我们希望在对不同对象下达相同指令(计算面积)的时候,不同对象可以根据自身情况完成该指令。即如果是Shape类则没有面积,而矩形和三角形各自都有计算面积的公式,以上代码看似是可以实现的,运行结果如下:

在这里插入图片描述
但是,这种情况实际上只是根据实例化时所属的类选择不同的area方法,属于静态多态,如果出现以下情况:

Shape* sha2 = rec;
sha2->area();

输出却为:“Parent class has no area”

明明sha2指向的地址是矩形类的地址,但是却因为实例化时用了Shape类,而导致无法正确计算面积,此时就有必要引入动态多态了。只需在Shape类中的area函数前加上virtual关键字即可:

#include <iostream> 
using namespace std;class Shape {
public:int width, height;Shape(int a = 0, int b = 0){width = a;height = b;}virtual void area(){cout << "Parent class has no area" << endl;}
};class Rectangle : public Shape {
public:Rectangle(int a = 0, int b = 0) :Shape(a, b) { }void area(){cout << "Rectangle class area :" << width * height << endl;}
};class Triangle : public Shape {
public:Triangle(int a = 0, int b = 0) :Shape(a, b) { }void area(){cout << "Triangle class area :" << width * height / 2 << endl;}
};int main()
{Shape* sha1 = new Shape(10, 5);Rectangle* rec = new Rectangle(10, 5);Triangle*  tri = new Triangle(10, 5);sha1->area();rec->area();tri->area();Shape* sha2 = rec;sha2->area();cin.get();return 0;
}

输出结果如下:

在这里插入图片描述
而如果我们在基类中不能对虚函数给出有意义的实现,这个时候就会用到纯虚函数。只需把函数体改为= 0即可:

#include <iostream> 
using namespace std;class Shape {
public:int width, height;Shape(int a = 0, int b = 0){width = a;height = b;}virtual void area() = 0;
};class Rectangle : public Shape {
public:Rectangle(int a = 0, int b = 0) :Shape(a, b) { }void area(){cout << "Rectangle class area :" << width * height << endl;}
};class Triangle : public Shape {
public:Triangle(int a = 0, int b = 0) :Shape(a, b) { }void area(){cout << "Triangle class area :" << width * height / 2 << endl;}
};int main()
{Rectangle* rec = new Rectangle(10, 5);Triangle*  tri = new Triangle(10, 5);rec->area();tri->area();Shape* sha2 = rec;sha2->area();cin.get();return 0;
}

注意此时我们无法实例化Shape类,因为它已经变成了抽象类,是作为一种规范,或者说接口而存在的。基类中定义了纯虚函数,子类必须对它进行定义,否则也是无法实例化的。

输出结果如下:

在这里插入图片描述

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/307685.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

.NET 5 自身就是一个 .NET Standard

微软2014年开源.NET的动作是实现一个全新的.NET Core ,从而引入了一个新的问题&#xff1a;选择代码的编译目标变得困难&#xff0c;需要面对3个环境。因此微软为了解决这个问题&#xff0c;引入了两个主要的概念&#xff1a;目标框架别名&#xff08;Target Framework Moniker…

Springboot后台管理(CRUD)

一:前言 这个就是用springboot实现后台管理(CRUD)的小demo,相比于SSM的配置地狱&#xff0c;springboot的自动配置确实很牛&#xff0c;tomcat都内置&#xff0c;我们想要修改相关的信息只要在yaml配置文件修改就行了&#xff0c;关于Dao层&#xff0c;这个mybatis-plus,quo实…

保护 .NET Core 项目的敏感信息

我们的项目中几乎都会有配置文件&#xff0c;里面可能会存储一些敏感信息&#xff0c;比如数据库连接字符串、第三方API的AppKey和SecretKey等。对于开源项目&#xff0c;这些敏感信息肯定不能随着源代码一起提交到托管平台。对于网站应用大多都是要部署到有公开IP的服务器上的…

matlab常用函数辨析

conv2() vs filter2() filter2做的是相关correlation&#xff0c;conv2做的是卷积convolution&#xff0c;卷积是会将模板翻转&#xff0c;而相关不会&#xff0c;具体看下面的例子 a magic(5)a 17 24 1 8 1523 5 7 14 164 6 13 20 …

背包(二维数组版和一维数组版)

一:前言 这是动态规划的经典题型&#xff0c;那么我们也是 按照动态规划五步走的策略分析的 确定dp数组的含义以及下标的含义确定dp数组的递推公式确定dp数组的初始化确定dp数组的遍历顺序举例验证&#xff08;如果不是做题可省略&#xff09; 二:二维数组 1:示例 2:dp数组…

Azure App Service 健康检查正式发布

点击上方蓝字关注“汪宇杰博客”原文&#xff1a;Jason Freeberg, Suwat Bodin翻译&#xff1a;汪宇杰导语通过App Service&#xff0c;可以在流量增加时自动将应用程序自动扩展到多个实例。这样可以提高您应用的吞吐量&#xff0c;但是如果其中一个实例发生未捕获的异常怎么办…

二叉树N叉数的前中后序遍历总结,python实现递归法和迭代法

关于二叉树的前序遍历&#xff08;preoder&#xff09;、中序遍历&#xff08;inorder&#xff09;和后序遍历&#xff08;postorder&#xff09;&#xff0c;实际上只需要记住&#xff1a;左子节点一定在右子节点的左边&#xff08;左右&#xff09;&#xff0c;所谓前中后序遍…

Azure Cosmos Db 介绍及演示

Azure Cosmos DB 是 Microsoft 提供的全球分布式多模型数据库服务。Cosmos DB是一种NoSql数据库&#xff0c;但是它兼容多种API。它支持SQL, MongoDB、Cassandra或 Gremlin&#xff0c;你可以挑选自己喜欢的方式进行存储跟访问。主要优势统包式全局分发凭借 Cosmos DB&#xff…

二叉树层序遍历(广度优先搜索)基础概念与经典题目(Leetcode题解-Python语言)

二叉树的广度优先搜索即从上到下、从左到右地进行搜索&#xff0c;对于层序遍历&#xff08;Level Order&#xff09;问题&#xff0c;即依次遍历第一层节点、第二层节点…等&#xff0c;基本可以秒杀。 广度优先搜索是通过队列来实现的&#xff0c;python中优先用collections…

leetcode049. 最后一块石头的重量 II

一:题目 二:上码 class Solution { public:/**思路:1.分析题意只要我们将石头分为尽可能相同的两堆,他们的重量相减后剩余的重量就是最小。 物品的重量为stones[i];物品的价值也为stone[i];temp代表总重量的一半那么我们最终得到的stones[temp]:就是背包容量为temp的最大重量为…

大改革,GNOME 3.x将直接跳到GNOME 40

GNOME 3.38 发布后&#xff0c;GNOME 基金会宣布了用于 GNOME 的新版本控制方案&#xff0c;将于2021年3月发布的下一版 GNOME 将是 GNOME 40。你没看错&#xff0c;版本号直接从现在的 3.x 跳到了 40。以 GNOME 40 为例&#xff0c;其开发周期将包含三个阶段&#xff0c;对应的…

从前中后序遍历构造二叉树,三题无脑秒杀

如果只是前中后序遍历的其中一种&#xff0c;是不可能唯一确定一个二叉树的&#xff0c;必须是其中两个的结合&#xff0c;由此便产生了三道题目&#xff0c;在这里可以全部秒杀。 需要记住的要点是&#xff1a; 前序&#xff08;根左右&#xff09;——第一个节点一定是根节点…

.NET Core + Kubernetes:StatefulSet

在 Kubernetes 中&#xff0c;Pod 资源的控制器 Deployment、Replicaset、Daemonset 等常用于管理无状态应用&#xff0c;它们所管理的 Pod 对应的 IP、名字&#xff0c;启停顺序等都是随机的&#xff0c;Pod 之间也并不存在任何关联关系。而实际情况下&#xff0c;在应用集群部…

哈希表(散列表)基础概念与经典题目(Leetcode题解-Python语言)之上——原理与设计

哈希表&#xff08;Hash table&#xff0c;也叫散列表&#xff09;&#xff0c;是根据键&#xff08;Key&#xff09;而直接访问数据在内存中的储存位置&#xff08;又叫做存储桶&#xff0c;Buckets&#xff09;的数据结构。也就是说&#xff0c;它通过计算一个关于键值的函数…

python编程中的小问题汇总

前言 本文记录了我在python编程中遇到的各种小问题&#xff0c;持续更新。 1. x x 1 VS x 1 辨析下面这两段代码&#xff1a; >>> x y [1, 2, 3, 4] >>> x [4] >>> x [1, 2, 3, 4, 4] >>> y [1, 2, 3, 4, 4]>>> x y …

都在讨论高并发,结果连并发量、TPS、QPS都分不清

“ 年年岁岁跳槽季&#xff0c;回回必问高并发&#xff01;原因很简单&#xff0c;因为高并发能牵扯出太多问题&#xff0c;接口响应超时、CPU负载升高、GC频繁、死锁、大数据量存储等&#xff0c;能考察求职者的真实情况。而很多人在第一步就倒下了&#xff01;因为对数据化的…

哈希表(散列表)基础概念与经典题目(Leetcode题解-Python语言)之中——实际应用

上一节介绍了哈希表的原理与设计方法&#xff0c;这一节则直接python中现有的哈希表类型&#xff1a;哈希集合 set&#xff08;集合&#xff09;和哈希映射 dict&#xff08;字典&#xff09;来解决实际应用&#xff08;刷题&#xff09;。 零、概念 在介绍实际应用之前&#…

leetcode518. 零钱兑换 II

一:题目 二:上码 class Solution { public:/**思路:1.分析题意这个满足答案的结果有很多种&#xff0c;所以我们可以用动态规划去做,那么题意中我们可以知道的是我们是可以输入一种面值的时候,我们是可以重复输入的&#xff0c;那么这就是背包类型中的完全背包了2.动态规划5步…

跟我一起学.NetCore之选项(Options)核心类型简介

前言.NetCore中提供的选项框架&#xff0c;我把其理解为配置组&#xff0c;主要是将服务中可供配置的项提取出来&#xff0c;封装成一个类型&#xff1b;从而服务可根据应用场景进行相关配置项的设置来满足需求&#xff0c;其中使用了依赖注入的形式&#xff0c;使得更加简单、…

哈希表(散列表)基础概念与经典题目(Leetcode题解-Python语言)之下——设计键

在很多应用中&#xff0c;我们会发现某种映射关系&#xff08;模式&#xff09;&#xff0c;但它并不是简单一 一对应的。这时&#xff0c;我们就要从键 key 入手&#xff0c;通过设计合适的键&#xff0c;建立映射关系。leetbook的这个章节总结了一些常见的键&#xff0c;以供…