实例讲解C++编程中的虚函数与虚基类_C 语言

虚函数

#include "stdafx.h"

#include <iostream>

using namespace std;

class B0//基类B0声明
{
public:
 void display(){cout<<"B0::display()"<<endl;}//公有成员函数
};

class B1: public B0//公有派生类B1声明
{
public:
 void display(){cout<<"B1::display()"<<endl;}//公有成员函数
};

class D1: public B1//公有派生类D1声明
{
public:
 void display(){cout<<"D1::display()"<<endl;}//公有成员函数
};

void fun(B0 *ptr)//普通函数
{//参数为指向基类对象的指针
 ptr->display();//"对象指针->成员名"
}
void main()//主函数
{
 B0 b0;//声明基类B0类对象
 B1 b1;//声明B1类对象
 D1 d1;//声明D1类对象
 B0 *p;//声明B0类指针
 p=&b0;//B0类指针指向B0类对象,
 fun(p);
 p=&b1;//B0类指针指向B1类对象,指向基类的指针也可以指向派生类。
 fun(p);
 p=&d1;//B0类指针指向D1类对象,指向基类的指针也可以指向派生类。
 fun(p);
}

输出结果:

B0::display()
B0::display()
B0::display()
Press any key to continue

类型兼容规则举例

#include "stdafx.h"

#include <iostream>

using namespace std;

class B0//基类B0声明
{
public:
 virtual void display(){cout<<"B0::display()"<<endl;}//公有成员函数
};

class B1: public B0//公有派生类B1声明
{
public:
 void display(){cout<<"B1::display()"<<endl;}//公有成员函数
};

class D1: public B1//公有派生类D1声明
{
public:
 void display(){cout<<"D1::display()"<<endl;}//公有成员函数
};

void fun(B0 *ptr)//普通函数
{//参数为指向基类对象的指针
 ptr->display();//"对象指针->成员名"
}
void main()//主函数
{
 B0 b0;//声明基类B0类对象
 B1 b1;//声明B1类对象
 D1 d1;//声明D1类对象
 B0 *p;//声明B0类指针
 p=&b0;//B0类指针指向B0类对象,
 fun(p);
 p=&b1;//B0类指针指向B1类对象,指向基类的指针也可以指向派生类。
 fun(p);
 p=&d1;//B0类指针指向D1类对象,指向基类的指针也可以指向派生类。
 fun(p);
}

输出结果:

B0::display()
B1::display()
D1::display()
Press any key to continue 

虚函数是为了实现某种功能而假设的函数,虚函数只能是类中的一个成员函数,不能是静态成员,使用关键字virtual用于在类中说明该函数是虚函数。 虚函数更是为了实现面向对象的多态性而产生的,使用虚函数和多态

性能够简化代码长度,支持更简单的顺序,便于程序的调试,维护。
虚函数的定义方法:

class A
{
  public:
    virtual void fun();  //define virtual function
};
void A::fun() { ... }      //member function describe

上面定义了一个虚函数,然后在类体外进行了函数的具体描述。

在类的继承当中,当基类中声明了某个虚函数,即使在派生类中没有声明虚函数,那么在以后的继承结构中都是

虚函数,当然如果有多重继承,在每个派生类中还是推荐对每个虚函数进行显式的声明。

为了说明虚函数在派生类中的应用,我写段代码作例子:

#include "stdio"
class cbase
{
public:
 virtual void vfoo()
 {
 printf("vfoo from cbase/n");
 };
 void foo()
 {
 printf("foo from cbase/n");
 }
};

class cderivd : public cbase
{
public:
 virtual void vfoo()
 {
 printf("vfoo from cderivd/n");
 };
 void foo()
 {
 printf("foo from cderivd/n");
 };
};

int main(int argc, char* argv[])
{
 cbase* pbase = new cderivd();
 pbase->foo(); //非虚函数,根据指针类型决定调用哪个foo,本例指针类型为cbase,所以调用的是cbase::foo()
 pbase->vfoo(); //虚函数,调用的是派生类的vfoo
 delete pbase;

 cderivd* pd = new cderivd();
 pd->foo();    //非虚函数,本例指针类型为cderivd*,所以调用cderivd::foo();
 pd->vfoo();
 delete pd;

 cderivd d;
 d.foo();
 d.vfoo();
 ((cbase)d).foo(); //将d强行切割为cbase,这时调用的无论是foo还是vfoo都将是base的
 ((cbase)d).vfoo();

 getchar();
 return 0;
}

程序在DevCPP下编译通过,输出:

foo from cbase
vfoo from cderivd
foo from cderivd
vfoo from cderivd
foo from cderivd
vfoo from cderivd
foo from cbase
vfoo from cbase

虚基类

#include "stdafx.h"

#include<iostream>
#include<string>

using namespace std;

class person{//声明基类
protected:
 int age;
 char sex;
 string name;
public:
 person(int a,char s,string nam){
 age=a;
 sex=s;
 name=nam;
 }
};
class teacher:virtual public person
{
protected:
 string title;
public:
 teacher(int a,char s,string nam,string t):person(a,s,nam){
 title=t;
 }
};
class student:virtual public person
{
protected:
 float score;
public:
 student(int a,char s,string nam,float sc):person(a,s,nam){
 score=sc;
 }
};
class graduate:public teacher,public student
{
protected:
 float wdge;
public:
 graduate(int a,char s,string nam,string t,float sc,float wd):person(a,s,nam),teacher(a,s,nam,t),student(a,s,nam,sc){
 wdge=wd;
 }
 void show(){
 cout<<name<<endl;
 cout<<age<<endl;
 cout<<sex<<endl;
 cout<<title<<endl;
 cout<<score<<endl;
 cout<<wdge<<endl;
 }
};
int main(){
 graduate gr(22,'f',"k;asdjf;daf","klsdaf",89.5,79.5);
 gr.show();
 return 0;
}

输出结果:

k;asdjf;daf
22
f
klsdaf
89.5
79.5
Press any key to continue

以上是小编为您精心准备的的内容,在的博客、问答、公众号、人物、课程等栏目也有的相关内容,欢迎继续使用右上角搜索按钮进行搜索c++
, 虚函数
虚基类
虚基类和虚函数、虚基类 虚函数、plc编程实例讲解、三菱plc编程实例讲解、vb编程实例讲解,以便于您获取更多的相关知识。

时间: 2024-10-31 13:41:15

实例讲解C++编程中的虚函数与虚基类_C 语言的相关文章

c++中虚函数和纯虚函数的作用与区别_C 语言

虚函数为了重载和多态的需要,在基类中是有定义的,即便定义是空,所以子类中可以重写也可以不写基类中的此函数! 纯虚函数在基类中是没有定义的,必须在子类中加以实现,很像java中的接口函数! 虚函数 引入原因:为了方便使用多态特性,我们常常需要在基类中定义虚函数. class Cman { public: virtual void Eat(){--}; void Move(); private: }; class CChild : public CMan { public: virtual void

详解C++中基类与派生类的转换以及虚基类_C 语言

C++基类与派生类的转换 在公用继承.私有继承和保护继承中,只有公用继承能较好地保留基类的特征,它保留了除构造函数和析构函数以外的基类所有成员,基类的公用或保护成员的访问权限在派生类中全部都按原样保留下来了,在派生类外可以调用基类的公用成员函数访问基类的私有成员.因此,公用派生类具有基类的全部功能,所有基类能够实现的功能, 公用派生类都能实现.而非公用派生类(私有或保护派生类)不能实现基类的全部功能(例如在派生类外不能调用基类的公用成员函数访问基类的私有成员).因此,只有公用派生类才是基类真正的

C++虚函数的实现机制分析_C 语言

本文针对C++的虚函数的实现机制进行较为深入的分析,具体如下: 1.简单地说,虚函数是通过虚函数表实现的.那么,什么是虚函数表呢? 事实上,如果一个类中含有虚函数,则系统会为这个类分配一个指针成员指向一张虚函数表(vtbl),表中每一项指向一个虚函数的地址,实现上就是一个函数指针的数组. 例如下面这个例子: class Parent { public: virtual void foo1() { } virtual void foo1() { } void foo1(); }; class Ch

虚函数与纯虚函数(C++与Java虚函数的区别)的深入分析_C 语言

c++虚函数1.定义:在某基类中声明为 virtual 并在一个或多个派生类中被重新定 义的成员函数 [1]2.语法:virtual 函数返回类型 函数名(参数表) { 函数体 }3.用途:实现多态性,通过指向派生类的基类指针,访问派生类中同名覆盖成员函数,也就是允许子类override父类同名方法.虚函数的作用是实现动态联编,也就是在程序的运行阶段动态地选择合适的成员函数,在定义了虚函数后,可以在基类的派生类中对虚函数重新定义,在派生类中重新定义的函数应与虚函数具有相同的形参个数和形参类型(也

构造函数不能声明为虚函数的原因及分析_C 语言

1. 从存储空间角度,虚函数对应一个指向vtable虚函数表的指针,这大家都知道,可是这个指向vtable的指针其实是存储在对象的内存空间的.问题出来了,如果构造函数是虚的,就需要通过 vtable来调用,可是对象还没有实例化,也就是内存空间还没有,怎么找vtable呢?所以构造函数不能是虚函数. 2. 从使用角度,虚函数主要用于在信息不全的情况下,能使重载的函数得到对应的调用.构造函数本身就是要初始化实例,那使用虚函数也没有实际意义呀.所以构造函数没有必要是虚函数.虚函数的作用在于通过父类的指

实例讲解C++编程中lambda表达式的使用_C 语言

函数对象与Lambdas你编写代码时,尤其是使用 STL 算法时,可能会使用函数指针和函数对象来解决问题和执行计算.函数指针和函数对象各有利弊.例如,函数指针具有最低的语法开销,但不保持范围内的状态,函数对象可保持状态,但需要类定义的语法开销. lambda 结合了函数指针和函数对象的优点并避免其缺点.lambda 与函数对象相似的是灵活并且可以保持状态,但不同的是其简洁的语法不需要显式类定义. 使用lambda,相比等效的函数对象代码,您可以写出不太复杂并且不容易出错的代码. 下面的示例比较l

实例讲解Java编程中数组反射的使用方法_java

什么是反射"反射(Reflection)能够让运行于JVM中的程序检测和修改运行时的行为."这个概念常常会和内省(Introspection)混淆,以下是这两个术语在Wikipedia中的解释: 内省用于在运行时检测某个对象的类型和其包含的属性: 反射用于在运行时检测和修改某个对象的结构及其行为. 从它们的定义可以看出,内省是反射的一个子集.有些语言支持内省,但并不支持反射,如C++. 内省示例:instanceof 运算符用于检测某个对象是否属于特定的类. if (obj insta

实例讲解C++编程中对设计模式中的原型模式的使用_C 语言

原型模式的实现完整代码示例(code):原型模式的实现很简单,这里为了方便初学者的学习和参考,将给出完整的实现代码(所有代码采用 C++实现,并在 VC 6.0 下测试运行). 代码片断 1:Prototype.h //Prototype.h #ifndef _PROTOTYPE_H_ #define _PROTOTYPE_H_ class Prototype{ public: virtual ~Prototype(); virtual Prototype* Clone() const = 0;

C++中的多态与虚函数的内部实现方法_C 语言

1.什么是多态 多态性可以简单概括为"一个接口,多种行为". 也就是说,向不同的对象发送同一个消息, 不同的对象在接收时会产生不同的行为(即方法).也就是说,每个对象可以用自己的方式去响应共同的消息.所谓消息,就是调用函数,不同的行为就是指不同的实现,即执行不同的函数.这是一种泛型技术,即用相同的代码实现不同的动作.这体现了面向对象编程的优越性. 多态分为两种: (1)编译时多态:主要通过函数的重载和模板来实现. (2)运行时多态:主要通过虚函数来实现. 2.几个相关概念 (1)覆盖.