课程咨询: 400-996-5531 / 投诉建议: 400-111-8989
认真做教育 专心促就业
函数的应用是每一位软件开发程序员都需要重点掌握的一个编程开发技术,下面我们就通过案例分析来简单了解一下,c++编程函数应用分析。
1、函数调用的栈分布
假设A函数调用B函数,B函数只有一个参数,函数调用时涉及到的入栈操作、栈底指针ebp和栈顶指针esp的处理。
上述函数调用的大致过程为:先将传给B函数的参数入栈,接着调用Call指令(Call指令涉及两步:将返回地址(下条指令的地址)压入栈,即返回地址是Call指令自动压入到栈中的,然后jump到被调用的函数地址),然后保存主调函数A的栈基址ebp,以及保护现场需要的其他寄存器,进入到B函数。B函数调用完成后,将栈顶指针ebp及其他寄存器值都pop出来,然后调用ret指令(将返回地址pop出来,然后jump到A函数中返回地址),后将调用函数的参数栈清掉。
ebp-函数栈基址寄存器,esp-函数栈顶地址寄存器。函数占用的栈空间(地址范围)就在esp中的栈顶地址到ebp中的栈基址之间,函数的栈空间在函数入口处就进行分配了。
2、关于call指令和ret指令的说明
简单地说,call指令会跳转到制定的地址处执行,并将下一条指令入;ret指令会退出当前函数,并从栈中取出下一条指令放到IP寄存器中,继续执行。
CPU执行call指令和ret指令的具体过程如下:
1)call指令:CPU将calls指令的机器码读入,IP寄存器指向了calls后的指令(函数调用的返回地址),然后CPU执行calls指令,将当前的IP寄存器的值压栈(push压栈操作会减esp),并将IP寄存器值改变为标号s处的偏移地址(即call指令中的函数地址);
2)ret指令:CPU将ret指令的机器码读入,IP寄存器指向了ret指令后的内存单元,然后CPU执行ret指令,从栈中弹出函数执行完后的返回地址(pop出栈操作会加esp),送入IP寄存器中。然后再执行IP寄存器中的指令,即返回地址,即调用函数下面的下一条指令。
此外,EIP寄存器是用来存放下一个CPU指令的地址(代码段地址),当CPU执行完当前指令后,从EIP寄存器中读取下一条指令的内存地址,然后继续执行。
【免责声明】:本内容转载于网络,转载目的在于传递信息。文章内容为作者个人意见,本平台对文中陈述、观点保持中立,不对所包含内容的准确性、可靠性与完整性提供形式地保证。请读者仅作参考。更多内容请加danei0707学习了解。欢迎关注“达内在线”参与分销,赚更多好礼。