滴水逆向——C++_动态绑定/多态

本文探讨了C++中的绑定概念,重点讲解了前期绑定与后期绑定(动态绑定、运行期绑定)的区别,并指出只有virtual函数实现动态绑定,即多态。通过实例分析了虚函数表在不同继承情况下的应用,包括单继承、多继承以及函数覆盖的各种场景。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

1、绑定概念
1.什么是绑定?
绑定就是将函数调用与地址关联起来.
观察下面代码反汇编

class Base				
{				
public:				
	int x;			
public:				
	Base()			
	{			
		x = 100;		
	}			
    void Function_1()				
    {				
        printf("Base:Function_1...\n");				
    }				
    virtual void Function_2()				
    {				
        printf("Base:Function_2...virtual\n");				
    }				
};				
class Sub:public Base				
{				
public:				
	int x;			
public:				
	Sub()			
	{			
		x = 200;		
	}			
    void Function_1()				
    {				
        printf("Sub:Function_1...\n");				
    }				
    virtual void Function_2()				
    {				
        printf("Sub:Function_2...virtual\n");				
    }				
};				
				
void TestBound(Base* pb)				
{				
	int n = pb->x;			
	printf("%x\n",n);			
				
	pb->Function_1();		//函数调用	
				
	pb->Function_2();			
}				
int main(int argc, char* argv[])				
{				
    				
				
	return 0;			
}				


2.什么是前期绑定?什么是后期绑定、动态绑定、运行期绑定?

总结:
           只有virtual的函数是动态绑定.
           动态绑定还有一个名字:多态

1、虚函数表:

struct Base							
{							
public:							
    virtual void Function_1()							
    {							
        printf("Function_1...\n");							
    }							
    virtual void Function_2()							
    {							
        printf("Function_2...\n");							
    }							
    virtual void Function_3()							
    {							
        printf("Function_3...\n");							
    }							
};							
							
							
							
int main(int argc, char* argv[])							
{							
	//查看 Base 的虚函数表						
    Base base;							
							
	//对象的前四个字节就是虚函数表						
	printf("Base 的虚函数表地址为:%x\n",*(int*)&base);						
							
	//虚函数表中第1个函数地址						
	printf("虚函数表中第1个函数地址:%x\n",*((int*)(*(int*)&base)+0));						
	//虚函数表中第2个函数地址						
	printf("虚函数表中第2个函数地址:%x\n",*((int*)(*(int*)&base)+1));						
	//虚函数表中第3个函数地址						
	printf("虚函数表中第3个函数地址:%x\n",*((int*)(*(int*)&base)+2));						
							
	//通过函数指针调用函数,验证正确性						
	typedef void(*pFunction)(void);						
							
	pFunction pFn;						
	pFn = (pFunction)*((int*)(*(int*)&base)+0);						
	pFn();						
	pFn = (pFunction)*((int*)(*(int*)&base)+1);						
	pFn();						
	pFn = (pFunction)*((int*)(*(int*)&base)+2);						
	pFn();						
							
	return 0;						
}							

2、单继承无函数覆盖

struct Base							
{							
public:							
    virtual void Function_1()							
    {							
        printf("Base:Function_1...\n");							
    }							
    virtual void Function_2()							
    {							
        printf("Base:Function_2...\n");							
    }							
    virtual void Function_3()							
    {							
        printf("Base:Function_3
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值