浅析面向对象编程语言C++多态实现技术的虚指针和虚表结构第二稿..docVIP

浅析面向对象编程语言C++多态实现技术的虚指针和虚表结构第二稿..doc

  1. 1、有哪些信誉好的足球投注网站(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
  2. 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  3. 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
  4. 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
  5. 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们
  6. 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
  7. 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
浅析面向对象编程语言C多态实现技术的虚指针和虚表结构第二稿.

浅析面向对象编程语言C++多态实现技术的虚指针和虚表结构 作者:翁子凡 摘要: 本文通过一个C++例子,探索C++类实现多态的虚表技术,验证了C++类结构中虚指针和虚表的真实存在,并且剖析了类结构中虚指针的位置和虚表中各个函数指针排列方式,并以表格的形式展示了出来。 关键字: 面向对象、编程语言、C++、多态、多态实现、虚指针、虚表 引言: 任何面向对象编程语言都有的相同三个重要特征,分别是封装、继承、多态,但是对于这三个特征的具体实现每种编程语言却有着不同的实现方式。C++是现在最流行的面向对象编程语言之一,其中C++对于多态的实现,是通过虚表来实现的。 正文: 时下最流行的编程语言是面向对象编程语言C++、C#、Java、Ruby,这是源于面向对象编程语言在工程实践中拥有的众多优点所致。对于实现这些优点,面向许多编程语言有着自己的技巧。本文试图揭示C++的多态实现虚表技术。 由于本文的目标读者是有C++编程基础的程序员,所以对于多态的概念就不在此赘述。 下面首先需要阐述的概念是虚表。 在C++语言中,每个有虚函数的类,编译器都会为它生成一个虚拟函数表(简称:虚表),表中的每一个元素都指向一个虚函数的地址。   此外,编译器当然也会为类加上一个成员,是一个指向该虚函数表的指针(常被称为vptr),每一个由此类别派生出来的类,都有这么一个vptr。 虚表的内容是依据类中的虚函数声明次序--填入函数指针。派生类别会继承基础类别的虚表(以及所有其他可以继承的成员),当我们在派生类中改写虚函数时,虚表就受了影响;表中的元素所指的函数地址将不再是基类的函数地址,而是派生类的函数地址。 上边对虚表的描述已经非常详细了,下边用一个代码示例和一些图表来更生动的阐述和验证。 代码中类之间继承结构图: 代码和注释: #include stdio.h #include iostream using namespace std; class CBase { public: virtual void fun1() { coutfun1 in CBaseendl; } virtual void fun2() { coutfun2 in CBaseendl; } virtual ~CBase(){};//虚函数地址在虚表中的位置和声明一致(VS2008) }; class CBase1 { public : virtual ~CBase1(){};//虚函数地址在虚表中的位置和声明一致 virtual void fun3() { coutfun3 in CBase1endl; } }; //继承了两个基类,这将使编译器在CDerive类中生成个虚表,每个基类都会有自己的虚函数表 class CDerive:public CBase,public CBase1 { public: CDerive() { } void fun1()//继承了两个基类,这将使编译器在CDerive类中生成个虚表, { coutfun1 in CDeriveendl; } }; //继承了两个基类,这将使编译器在CDerive1类中生成个虚表,每个基类都会有自己的虚函数表,自己的虚函数会添加到第一张虚表的最后 class CDerive1:public CBase,public CBase1 { public: CDerive1() { } void fun1() { coutfun1 in CDerive1endl; } virtual void fun4() { coutfun4 in CDeriveendl; } }; //继承了一个基类CDerive1,这将使编译器在CDerive2类中继承CDerive1的两张基表 class CDerive2:public CDerive1 { void fun1() { coutfun1 in CDerive2endl; } }; //函数指针 typedef void(*Func)(void); //打印函数地址,并调用函数 void callFunctionAtAddress(int nAddress) { printf(Call function at address:0x%x\r\n,nAddress); Func fun = (Func)nAddress; fun(); } int main(int argc, char argv[]) { CDerive2 *pObj = new CDerive2; printf(size of CBase:%d\r\nsize of CBase1:%d\r\nsize of CDeriv

文档评论(0)

s4c2bg5I + 关注
实名认证
文档贡献者

该用户很懒,什么也没介绍

1亿VIP精品文档

相关文档