c语言 虚函数,C语言模拟虚函数表

85cd44a3cc2cef49f342cb44466601c8.png

使用C语言模拟虚函数表的实现。

/* 模似的虚函数表

* pVtable vtable

* 接口指针 ---> 虚函数表指针 ---> 指针函数1 --->

* 指针函数2 ---> 对象实现

* 指针函数3 --->

*/

#include

#include

// 前向声明

struct IDictionaryVtable;

// 模似接口指针

struct IDictionary

{

// 虚函数表指针

IDictionaryVtable *pVtable;

};

// 模拟的虚函数表

struct IDictionaryVtable

{

bool (*Initialize)( IDictionary *pThis );

bool (*LoadLibrary)( IDictionary *pThis, char *source );

bool (*FreeLibrary)( IDictionary *pThis );

};

void InitVtable( IDictionary *pInterface );

bool InitFoo( IDictionary *pThis );

bool LoadFoo( IDictionary *pThis, char *pString );

bool FreeFoo( IDictionary *pThis );

int main()

{

// 实现接口指针

IDictionary *pi = (IDictionary*) malloc( sizeof( IDictionary ) );

InitVtable( pi );

printf( "pi: %Xn" );

printf( "pi->pVtable: %Xn", pi->pVtable );

pi->pVtable->Initialize( pi );

pi->pVtable->LoadLibrary( pi, "Phoebe" );

pi->pVtable->FreeLibrary( pi );

return 0;

}

// 初始化虚函数表

void InitVtable( IDictionary *pInterface )

{

pInterface->pVtable = (IDictionaryVtable*) malloc( sizeof( IDictionaryVtable ) );

pInterface->pVtable->Initialize = InitFoo;

pInterface->pVtable->LoadLibrary = LoadFoo;

pInterface->pVtable->FreeLibrary = FreeFoo;

}

// 初始化过程

bool InitFoo( IDictionary *pThis )

{

printf( "Init function: pThis->pVtable: %Xn", pThis->pVtable );

return true;

}

// 加载过程

bool LoadFoo( IDictionary *pThis, char *pString )

{

printf( "Load function: pThis->pVtable: %X pString: %sn", pThis->pVtable, pString );

return true;

}

// 释放过程

bool FreeFoo( IDictionary *pThis )

{

printf( "Free function: pThis->pVtable: %Xn", pThis->pVtable );

return true;

}

多态类对象的大小是由其非静态成员变量的总大小加上一个指向虚函数的指针的大小决定的。这个指针通常称为虚函数指针(VTable Pointer),用于指向存储类虚函数地址的虚函数虚函数是一个数组,每个元素都是一个指向虚函数的指针。 在C++虚函数指针是由编译器自动生成的,用于实现动态绑定。通常,虚函数指针位于类对象的起始位置,因此可以通过访问类对象的第一个字节来获取虚函数指针。 模拟实现虚函数指针可以使用一个结构体来虚函数,每个元素都是一个指向虚函数的指针,然后将这个结构体的地址赋给虚函数指针。下面是一个示例代码: ``` class Animal { public: virtual void speak() { std::cout << "Animal speaks!" << std::endl; } }; class Cat : public Animal { public: virtual void speak() { std::cout << "Meow!" << std::endl; } }; int main() { Animal* animal = new Cat(); animal->speak(); // 模拟实现虚函数指针 typedef void(*Fun)(); Fun pFun = NULL; Fun* pVTable = (Fun*)*(int*)animal; pFun = (Fun)pVTable[0]; pFun(); delete animal; return 0; } ``` 这段代码,我们创建了一个Cat类的实例,并将其强制转换为Animal指针类型。然后,我们使用模拟实现的方法访问虚函数指针,并通过指针调用虚函数。最后,我们释放了动态分配的内存。 需要注意的是,这种模拟实现方式只是为了说明虚函数指针的原理,实际上编译器会自动生成虚函数指针和虚函数,并将其包含在类对象
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值