虚函数 单继承无重写(overwrite)

#include <stdio.h>

struct Base
{
    virtual void func1()
    {
        printf("Base func1()\n");
    }
    virtual void func2()
    {
        printf("Base func2()\n");
    }
    virtual void func3()
    {
        printf("Base func3()\n");
    }

};
struct Sub:Base
{
    virtual void func4()
    {
        printf("Sub func4()\n");
    }
    virtual void func5()
    {
        printf("Sub func5()\n");
    }
    virtual void func6()
    {
        printf("Sub func6()\n");
    }
};

void test()
{
    int i = 0;
    Sub s;
    typedef void (*pFun)(void);
    pFun fun = NULL;
    for (i = 0; i < 6; i++) {
        fun = (pFun)(*((long int *)(*(long int *)&s) + i));
        fun();
    }
}

int main(int argc, char **argv)
{
    test();
}

时间: 2024-10-28 20:36:16

虚函数 单继承无重写(overwrite)的相关文章

【整理】C++虚函数及其继承、虚继承类大小

参考文章: http://blog.chinaunix.net/uid-25132162-id-1564955.html http://blog.csdn.net/haoel/article/details/1948051/ 一.虚函数与继承 1.空类,空类单继承,空类多继承的sizeof #include <iostream> using namespace std; class Base1 { }; class Base2 { }; class Derived1:public Base1

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在申请内存空间时可进

虚函数 多重继承无重写(overwrite)

#include <stdio.h> struct Base1{    virtual void func1()    {        printf("Base1 func1()\n");    }    virtual void func2()    {        printf("Base1 func2()\n");    } };struct Base2{    virtual void func3()    {        printf(&

宏接口实现纯虚函数类继承

//下列代码编译过,楼主先保存- - 1 #include <iostream> 2 #include <string> 3 4 5 #define INTERFACE_ANIMAL(terminal) 6 public: 7 virtual std::string GetName() const ##terminal 8 virtual void GetPosition() const ##terminal 9 virtual void GetVelocity() const #

C++ 无虚函数的单继承内存模型

C++类因为有继承的存在要比C时代的struct复杂得一些,特别是加上有虚函数的时候,以及多继承等这些特性更是令其内存布局变得面目全非.说实在的我也把握不了,我只是在一个实际的平台上进行了一些探索而已,并用此篇笔记将我的探索成果记录下来. 虽然说有些东西在C++标准里面没有规定如何做,不同的实现可能会有不同的作法,但是了解一个实际的系统是如何做的也会有益于我们更加深入的了解C++或者举一反三地理解其他的实现,而且如果我们了解了自己所用的系统上的具体实现的话,就可以对其为所欲为. 没有虚函数单继承

虚函数实现原理之虚函数表

引言 C++使用虚函数来实现多态机制,大多数编译器是通过虚函数表来实现动态绑定. 类的内存布局 1.普通类 class B { public: int m; int n; }; int main() { printf("%ld\n", sizeof(B)); B b; printf("%p, %p, %p\n", &b, &b.m, &b.n); return 0; } 类中只有普通成员变量,对象在内存中顺序存储成员变量.输出: 8 0x7f

看到的关于虚函数继承及虚继承解释比较好的文章的复制

(来源于:http://blog.chinaunix.net/uid-25132162-id-1564955.html) 1.空类,空类单继承,空类多继承的sizeof #include <iostream> using namespace std; class Base1 { }; class Base2 { }; class Derived1:public Base1 { }; class Derived2:public Base1, public Base2 { }; int main(

C++之虚函数与虚继承详解

准备工作 1.VS2012使用命令行选项查看对象的内存布局 微软的Visual Studio提供给用户显示C++对象在内存中的布局的选项:/d1reportSingleClassLayout.使用方法很简单,直接在[项目P]选项下找到"visual属性"后点击即可.切换到cpp文件所在目录下输入如下的命令即可 c1 [filename].cpp /d1reportSingleClassLayout[className] 其中[filename].cpp就是我们想要查看的class所在的

C++虚函数作用原理(二)——类的继承

上一篇博客 C++虚函数作用原理(一) 开始 上一篇博客我们了解了虚函数到底是怎么存在的,那么这一篇我们就要开始考虑:虚函数的继承问题了. 首先我们可以回忆一下,我们之前在学习继承的时候存在函数覆盖这个概念.如果没有函数覆盖,那么当我们调用子类中和父类同名函数时,就会出现二义性,编译器无法知道你到底需要哪一个函数.那么对于虚函数的继承我们是不是也应该考虑同名函数的覆盖问题呢?----当然应该,那么这里我们就来通过代码验证一下: class A { int x; int y; public: vi