1、思考
在函数调用的过程我们可以看作是一个调用链。
例如:在main函数中调用Sum函数,其中main为调用方,Sum为被调用方
问题一:被调用方执行完后,怎么回退到调用方函数???
问题二:被调用方函数执行完回到调用方函数后,怎么知道延下一行继续执行??
问题三:返回值是由什么带出来的??
问题四:形参需不需要开辟内存?如果形参开辟内存,在哪里开辟的?
2、在虚拟地址空间有一块区域,称为栈区,它是所有函数的活动区域。
而栈区是由栈帧组成的,栈帧是每一个函数的活动区域。
3、知道栈后,想要解决上面的问题还需要通过在底层通过反汇编看每一天指令的运行。
4、汇编
汇编分为(1)Linux下的AT&T(2)Windows下的inter X86
两者的区别举例说明:int a = 10;
在Linux下汇编的指令是 mov 0a , dword ptr[a]
,
在Windows下汇编的指令是 mov dword ptr[a] , 0a
则除操作码以外,Linux下是从左往右看。Windows下是从右往左看。
5、寄存器
(1)用来存储数据的寄存器:eax 、ebx、ecx、edx
(2)栈底指针寄存器:ebp;栈顶指针寄存器:esp
栈顶指针寄存器和栈底指针寄存器共同标识一个栈帧。
(3)pc下一行指令寄存器
6、汇编指令
(1)mov 移值指令
a = 20;
反汇编:mov dwoad ptr[a],14 //表示把20放在a的地址下,