探讨虚函数与纯虚函数的区别

2024-03-10 02:38
文章标签 函数 区别 探讨 纯虚

本文主要是介绍探讨虚函数与纯虚函数的区别,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

转载请注明t1234xy4原创:http://blog.csdn.net/t1234xy4/article/details/51191270
《C++ Primer》书上学习得到的基础:
纯虚函数:
1、纯虚函数只声明,没有定义。书写=0说明为纯虚函数。
2、含有纯虚函数的内,称为抽象基类,所谓抽象基类只负责定义接口,后续的其他类可以覆盖该接口,我们不能创建抽象基类的实例。
3、能够被覆盖。

普通虚函数:
1、声明为普通函数前加virtual,不仅要申明,而且必须定义。
2、能够被覆盖。(只有虚函数能够被覆盖)

测试虚函数与纯虚函数区别:
测试1、测试纯虚函数能不能有重名而函数个数不同的重载:
//virtualBase.hxx:

#include <string>
#include <iostream>
#pragma once
using namespace std;
class VirtualBase
{
public:VirtualBase(void);virtual void  helloword(string s)=0;virtual void helloword(string s1,string s2)=0;~VirtualBase(void);
};

virtualclass 继承了virtualBase

VirtualClass.hxx :

#pragma once
#include "virtualbase.h"
#include "VirtualBaseCopy.h"
class VirtualClass :public VirtualBase/*,public VirtualBaseCopy*/
{
public:VirtualClass(void);virtual void helloword(string s);virtual void helloword(string s1,string s2);~VirtualClass(void);
};

virtualclass.c

#include "StdAfx.h"
#include "VirtualClass.h"void VirtualClass::helloword(string s1,string s2)
{cout << "VirtualClass: hello ,"<<s1 <<","<<s2<<endl;
}
void VirtualClass::helloword(string s)
{cout << "virtualclass: hello,"<<s<<endl;
}

Main.c:

int _tmain(int argc, _TCHAR* argv[])
{**VirtualBase *base = new VirtualClass; //注意此处**string s = "jack";string s2 = "rose";base->helloword(s,s2);base->helloword(s);while (1){}return 0;
}

执行结果如下:
这里写图片描述
测试1结论:如果基类拥有重载纯虚函数接口,子类分别实例化后可用。也就是说,子类重写的两个函数分别覆盖了基类的两个函数。

测试2:如果基类VirtualBase中只有其中一个接口?,子类中是否可以出现同名的函数。
修改VirtualBase.hxx如下:

#include <string>
#include <iostream>
#pragma once
using namespace std;
class VirtualBase
{
public:VirtualBase(void);//virtual void  helloword(string s)=0;virtual void helloword(string s1,string s2)=0;~VirtualBase(void);
};
int _tmain(int argc, _TCHAR* argv[])
{**VirtualClass *base = new VirtualClass;**//注意此处string s = "jack";string s2 = "rose";base->helloword(s,s2);base->helloword(s);//cout<<base->add(2,3);while (1){}return 0;
}

结果:
这里写图片描述

修改为下面的后:

**VirtualBase *base = new VirtualClass;**//注意此处

编译不通过。
测试2结论:
1、编译不通过在情理之中,基类的指针开辟的空间结构不具有另一个函数的指针。
2、helloword(string s1,string s2)是VirtualClass的虚函数可行,运行没有问题。也就是说,子类可以出现与父类接口同名的函数。

虚函数是可以连续继承的。也就是说,一个函数在基类中为虚函数,那么在他的子子孙孙类中都是虚函数。

测试3: VirtualClass的子类还能否够继承他
我们添加类VirtualConcreate继承VirtualClass类,并重写虚函数helloword(string s):

void VirtualConcreate::helloword(string s)
{cout<<"concrete:hello,"<<s<<endl;
}

实例化如下:

**VirtualBase *base = new VirtualConcreate;**

结果如下:
这里写图片描述

测试3结论如下:
1、如果在VirtualConcrete类中,函数中重写了父类的虚函数,那么父类的虚函数将被覆盖掉;
2、子类中没有重写的父类函数,直接调用父类函数;

测试4:基类的接口,在其派生类中出现了与接口同名(函数个数不同或者参数不同)的虚函数是否一起被继承。
这里写图片描述
测试4结论:可以一起被继承。

测试总结:虚函数也可用重载,纯虚函数一样可以重载。,只有形参类型完全相同的虚函数才会被覆盖!!

测试5:普通成员函数与虚函数区别。
虚函数:
1、只有虚函数才能被覆盖(《C++ primer(第5版)》 538页)
2、虚函数是动态绑定

成员函数:
1、成员函数是静态绑定

这篇关于探讨虚函数与纯虚函数的区别的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/792752

相关文章

Conda与Python venv虚拟环境的区别与使用方法详解

《Conda与Pythonvenv虚拟环境的区别与使用方法详解》随着Python社区的成长,虚拟环境的概念和技术也在不断发展,:本文主要介绍Conda与Pythonvenv虚拟环境的区别与使用... 目录前言一、Conda 与 python venv 的核心区别1. Conda 的特点2. Python v

Go语言中make和new的区别及说明

《Go语言中make和new的区别及说明》:本文主要介绍Go语言中make和new的区别及说明,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录1 概述2 new 函数2.1 功能2.2 语法2.3 初始化案例3 make 函数3.1 功能3.2 语法3.3 初始化

MySQL 中的 CAST 函数详解及常见用法

《MySQL中的CAST函数详解及常见用法》CAST函数是MySQL中用于数据类型转换的重要函数,它允许你将一个值从一种数据类型转换为另一种数据类型,本文给大家介绍MySQL中的CAST... 目录mysql 中的 CAST 函数详解一、基本语法二、支持的数据类型三、常见用法示例1. 字符串转数字2. 数字

Python内置函数之classmethod函数使用详解

《Python内置函数之classmethod函数使用详解》:本文主要介绍Python内置函数之classmethod函数使用方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地... 目录1. 类方法定义与基本语法2. 类方法 vs 实例方法 vs 静态方法3. 核心特性与用法(1编程客

Python函数作用域示例详解

《Python函数作用域示例详解》本文介绍了Python中的LEGB作用域规则,详细解析了变量查找的四个层级,通过具体代码示例,展示了各层级的变量访问规则和特性,对python函数作用域相关知识感兴趣... 目录一、LEGB 规则二、作用域实例2.1 局部作用域(Local)2.2 闭包作用域(Enclos

MySQL count()聚合函数详解

《MySQLcount()聚合函数详解》MySQL中的COUNT()函数,它是SQL中最常用的聚合函数之一,用于计算表中符合特定条件的行数,本文给大家介绍MySQLcount()聚合函数,感兴趣的朋... 目录核心功能语法形式重要特性与行为如何选择使用哪种形式?总结深入剖析一下 mysql 中的 COUNT

MySQL 中 ROW_NUMBER() 函数最佳实践

《MySQL中ROW_NUMBER()函数最佳实践》MySQL中ROW_NUMBER()函数,作为窗口函数为每行分配唯一连续序号,区别于RANK()和DENSE_RANK(),特别适合分页、去重... 目录mysql 中 ROW_NUMBER() 函数详解一、基础语法二、核心特点三、典型应用场景1. 数据分

深度解析Spring Boot拦截器Interceptor与过滤器Filter的区别与实战指南

《深度解析SpringBoot拦截器Interceptor与过滤器Filter的区别与实战指南》本文深度解析SpringBoot中拦截器与过滤器的区别,涵盖执行顺序、依赖关系、异常处理等核心差异,并... 目录Spring Boot拦截器(Interceptor)与过滤器(Filter)深度解析:区别、实现

MySQL数据库的内嵌函数和联合查询实例代码

《MySQL数据库的内嵌函数和联合查询实例代码》联合查询是一种将多个查询结果组合在一起的方法,通常使用UNION、UNIONALL、INTERSECT和EXCEPT关键字,下面:本文主要介绍MyS... 目录一.数据库的内嵌函数1.1聚合函数COUNT([DISTINCT] expr)SUM([DISTIN

Python get()函数用法案例详解

《Pythonget()函数用法案例详解》在Python中,get()是字典(dict)类型的内置方法,用于安全地获取字典中指定键对应的值,它的核心作用是避免因访问不存在的键而引发KeyError错... 目录简介基本语法一、用法二、案例:安全访问未知键三、案例:配置参数默认值简介python是一种高级编