c++ 输出虚函数表内容

class Base{
	public:
		virtual void f(){cout<<"Base::f"<<endl;}
		virtual void g(){cout<<"Base::g"<<endl;}
		virtual void h(){cout<<"Base::h"<<endl;}

};
typedef void (*Fun)(void);
int main(){
	Base b;
	cout<<"虚函数表首地址:"<<*(int*)(&b)<<endl;
	cout<<"虚函数表第一个函数的存储地址:"<<((int*)(*(int *)(&b)))<<endl;
	cout<<"虚函数表第一个函数的入口地址:"<<*((int*)(*(int *)(&b)))<<endl;
	Fun pFun=NULL;
	pFun=(Fun)*((int*)(*(int *)(&b)));
	pFun();
	pFun=(Fun)*((int*)(*(int *)(&b))+1);
	pFun();
	pFun=(Fun)*((int*)(*(int *)(&b))+2);
	pFun();
	return 0;
}

程序运行结果:

时间: 2024-08-07 20:02:43

c++ 输出虚函数表内容的相关文章

C++ 关于类与对象在虚函数表上唯一性问题 浅析

[摘要] 很多教材上都有介绍到虚指针.虚函数与虚函数表,有的说类对象共享一个虚函数表,有的说,一个类对象拥有一个虚函数表:还有的说,无论用户声明了多少个类对象,但是,这个VTABLE虚函数表只有一个:也有的在说,每个具有虚函数的类的对象里面都有一个VPTR虚函数指针,这个指针指向VTABLE的首地址,每个类的对象都有这么一种指针.今天,我们就来解决这个问题,同一个类的不同对象,是不是拥有"相同"的虚函数表,这个相同是物理上的相同(内存地址)还是逻辑上的相同(数据结构).本文现详述如下!

c++ 继承类强制转换时的虚函数表工作原理

本文通过简单例子说明子类之间发生强制转换时虚函数如何调用,旨在对c++继承中的虚函数表的作用机制有更深入的理解. #include<iostream> using namespace std; class Base { public: virtual void f() { cout<<"Base::f()"<<endl; } }; class child1:public Base { public: virtual void f() { cout&l

C++中的虚函数表是什么时期建立的?(阿里内推面试题)

虚函数表是在什么时期建立的? 最近参加阿里巴巴公司的内推,面试官问了“虚函数表是在什么时期建立的?”.因为以前对虚函数表的理解不够多,所以就根据程序构建(Build)的四个过程(预编译.编译.汇编和链接),推导出虚函数表应该是在编译器确定的,原因如下: 1)预编译器主要处理那些源代码文件中的以“#”开始的预编译指令,如“#include”.“#define”.很明显这个过程可以排除. 2)汇编器是将编译器生成的汇编代码转变成机器可以执行的指令,每一个汇编语句几乎都对应一条机器指令.汇编过程相对于

C++学习 - 虚表,虚函数,虚函数表指针学习笔记

虚函数 虚函数就是用virtual来修饰的函数.虚函数是实现C++多态的基础. 虚表 每个类都会为自己类的虚函数创建一个表,来存放类内部的虚函数成员. 虚函数表指针 每个类在构造函数里面进行虚表和虚表指针的初始化. 下面看一段代码: // // main.cpp // VirtualTable // // Created by Alps on 15/4/14. // Copyright (c) 2015年 chen. All rights reserved. // #include <iostr

查看虚函数表

如果你看到这篇文章时,急着去吃饭或泡MM,请跳转到蓝色字段开始阅读. C++中的虚函数的作用主要是实现了多态的机制.关于多态,简而言之就是用父类型别的指针指向其子类的实例,然后通过父类的指针调用实际子类的成员函数.这种技术可以让父类的指针有“多种形态”,这是一种泛型技术.所谓泛型技术,说白了就是试图使用不变的代码来实现可变的算法.比如:模板技术,RTTI技术,虚函数技术,要么是试图做到在编译时决议,要么试图做到运行时决议. 关于虚函数的使用方法,我在这里不做过多的阐述.大家可以看看相关的C++的

C++虚函数和虚函数表

前导 在上面的博文中描述了基类中存在虚函数时,基类和派生类中虚函数表的结构. 在派生类也定义了虚函数时,函数表又是怎样的结构呢? 先看下面的示例代码: 1 #include <iostream> 2 3 using namespace std; 4 5 class A 6 { 7 public: 8 virtual void funcA(){ cout<<"A"<<endl; } 9 }; 10 11 class B 12 { 13 public:

C++类成员空间分配和虚函数表

最近在自学python,看到继承和类,就顺便复习了C++的类和继承等方面的知识. 先看Base基类 class Base { private: virtual void display() { cout<<"Base display()"<<endl; } void say(){ cout<<"Base say()"<<endl; } public: virtual void func(){cout <<

C++ Primer 学习笔记_35_面向对象编程(6)--虚函数与多态(三):虚函数表指针(vptr)及虚基类表指针(bptr)、C++对象模型

C++ Primer 学习笔记_35_面向对象编程(6)--虚函数与多态(三):虚函数表指针(vptr)及虚基类表指针(bptr).C++对象模型 一.虚函数表指针(vptr)及虚基类表指针(bptr) C++在布局以及存取时间上主要的额外负担是由virtual引起的,包括: virtual function机制:用以支持一个有效率的"执行期绑定": virtual base class:用以实现多次在继承体系中的基类,有一个单一而被共享的实体. 1.虚函数表指针 C++中,有两种数据

C++程序设计POJ》《WEEK6 多态与虚函数》《多态的实现原理》《虚函数表》

“多态”的关键在于通过基类指针或引用调用一个虚函数时,编译时不确定到底调用的是基类还是派生类的函数,运行时才确定---- 这叫“动态联编”.“动态联编” 底是怎么实现的呢? #include<iostream> using namespace std; class Base { public: int i; virtual void Print() { cout << "base:print"; } }; class Derived :public Base {