汇编语言call指令与ret指令的研究
这阵子一直在研究王爽的《汇编语言》一书,写得真是很不错。
在这里对第十章的call与ret指令进行一下总结与研究。
实际上,call与ret(或retf)指令都是通过修改ip(或cs ip)来实现地址的转移。
cpu执行ret指令时,进行下面两步操作:
(1)(ip)=((ss)*16+sp)
(2)(sp)=(sp)+2
就是从栈里提出ip
用汇编语言描述即:
pop ip
而retf则为
pop ip
pop cs
call指令与ret指令刚好相反,
call是将ip压入栈中,再进行转移。
不过在此要注意的是 call压入的ip是call指令下一条指令的ip。
相当于:
push ip
jmp near(far) ptr 标号(内存单元地址) /*call指令不能实现短转移*/
call指令与ret指令结合就可以编写子程序。
我发现这就和c/c++里的调用函数功能有些相似。
转自:http://hi.baidu.com/tcgx/blog/item/df1f2de9581f8637b80e2d52.html