C++虚函数示例

和Java不同,CDerive derive语句可以直接生成对象,不需要new关键字

重载虚函数才可以用父类引用调用子类对象,重载普通函数没有效果


#include<iostream>
#include<tchar.h>
using namespace std;
class CBase
{
public :
void fun()
{
cout<<_T("CBase:fun")<<endl;
}
virtual void vfun1()
{
cout<<_T("CBase:vfun1")<<endl;
}
virtual void vfun2()
{
cout<<_T("CBase:vfun2")<<endl;
}
};

class CDerive:public CBase
{
public :
void fun()
{
cout<<_T("CDerive:fun")<<endl;
}
virtual void vfun1()
{
cout<<_T("CDerive:vfun1")<<endl;
}
};

int _tmain(int argc, _TCHAR* argv[])
{
CDerive derive;
CBase* pBase = (CBase*)&derive;
pBase->fun();
pBase->vfun1();
pBase->vfun2();

cout<<hex<<*((int*)(*((int*)&derive)))<<endl;
cout<<hex<<*((int*)(*((int*)&derive))+1)<<endl;
cin.get();
return 0;
}

C++虚函数示例,布布扣,bubuko.com

时间: 2024-08-25 11:05:37

C++虚函数示例的相关文章

c++ 虚函数详解

下面是对C++的虚函数的理解. 一,定义 简单地说,那些被virtual关键字修饰的成员函数,就是虚函数.虚函数的作用,用专业术语来解释就是实现多态性(Polymorphism),多态性是将接口与实现进行分离:用形象的语言来解释就是实现以共同的方法,但因个体差异而采用不同的策略.下面来看一段简单的代码 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 classA { publi

不可或缺 Windows Native (23) - C++: 虚函数

[源码下载] 作者:webabcd 介绍不可或缺 Windows Native 之 C++ 虚函数 示例1.基类CppHuman.h #pragma once #include <string> using namespace std; namespace NativeDll { class CppHuman { protected: string Name; public: // 我是虚函数 virtual string Show(); // 我是纯虚函数(后面的“=0”只起形式上的作用,用

C++纯虚函数

虚函数联系到多态,多态联系到继承,没有了继承,什么都是不成立的. 一:什么是虚函数? 简单地说,那些被virtual关键字修饰的成员函数,就是虚函数.虚函数的作用,用专业术语来解释就是实现多态性(Polymorphism),多态性是将接口与实现进行分离:用形象的语言来解释就是实现以共同的方法,但因个体差异而采用不同的策略.下面来看一段简单的代码 1 class A{ 2 public: 3 void print() {cout<<"This is A"<<end

解释:C++虚函数

一, 什么是虚函数(如果不知道虚函数为何物,但有急切的想知道,那你就应该从这里开始) 简单地说,那些被virtual关键字修饰的成员函数,就是虚函数.虚函数的作用,用专业术语来解释就是实现多态性(Polymorphism),多态性是将接口与实现进行分离:用形象的语言来解释就是实现以共同的方法,但因个体差异而采用不同的策略.下面来看一段简单的代码: class A{ public: void print(){ cout<<"This is A"<<endl;} }

C++学习笔记——虚函数

基本概念 虚函数是在某基类中声明为 virtual 并在一个或多个派生类中被重新定义的成员函数,用法格式为: virtual 函数返回类型 函数名(参数表) {函数体}: C++中用它来实现多态性,通过指向派生类的基类指针或引用,访问派生类中同名覆盖成员函数. 虚函数实现机制 虚函数是如何做到因对象的不同而调用其相应的函数的呢? 现在我们就来剖析虚函数.我们先定义两个类 class A{//虚函数示例代码 public: virtual voidfun(){cout<<1<<end

C++解析(25):关于动态内存分配、虚函数和继承中强制类型转换的疑问

0.目录 1.动态内存分配 1.1 new和malloc的区别 1.2 delete和free的区别 2.虚函数 2.1 构造函数与析构函数是否可以成为虚函数? 2.2 构造函数与析构函数是否可以发生多态? 3.继承中的强制类型转换 4.小结 1.动态内存分配 1.1 new和malloc的区别 new关键字与malloc函数的区别: new关键字是C++的一部分 malloc是由C库提供的函数 new以具体类型为单位进行内存分配 malloc以字节为单位进行内存分配 new在申请内存空间时可进

31.C++-虚函数之构造函数与析构函数分析

1.构造函数不能为虚函数 当我们将构造函数定义为虚函数时,会直接报错: 首先回忆下以前学的virtual虚函数概念: 如果类定义了虚函数,创建对象时,则会分配内存空间,并且为该父类以及其所有子类的内存空间上额外分配一个虚函数表. 虚函数表的作用在于,存储每个类的相同的虚函数名,然后每一次虚函数调用,都会去虚函数表查找地址 分析: 假如构造函数是虚函数的话,由于对象开始还未分配内存空间,所以根本就无法找到虚函数表,从而构造函数也无法被调用.所以构造函数是不能成为虚函数. 2. 析构函数可以为虚函数

单继承与多继承中的虚函数表和虚函数指针

首先,我们了解一下何为单继承,何为多继承?? 单继承:一个子类只有一个直接父类. 多继承:一个子类有两个或多个直接父类. 单继承中的虚函数表分析: 示例程序: #include <iostream> using namespace std; typedef void(*FUNC)(); class Base { public: virtual void func1() { cout << "Base::func1()" << endl; } virt

第八章:不要在构造和析构函数中使用虚函数

前言 本文将讲解一个新手C++程序员经常会犯的错误 - 在构造/析构函数中使用虚函数,并分析错误原因所在以及规避方法. 错误起因 首先,假设我们以一个实现交易的类为父类,然后一个实现买的类,一个实现卖的类为其子类. 这三个类的对象初始化过程中,都需要完成注册的这么一件事情 (函数).然而,各自注册的具体行为是不同的. 有些人会写出以下这样的代码: 1 class Transaction { 2 public: 3 Transaction(); // 父类构造函数 4 //...... 5 pri