您的位置:首页 > 其它

汇编基础教程(二)——常用汇编指令之传送指令

2012-10-29 17:05 435 查看
原文地址:http://www.tinpont.com/knowledge/assembly_instruction_move.html

-----------------------------------------------------------------------------------分割线-----------------------------------------------------------------------------------

经过前面的学习,相信大家对寄存器产生了一点印象。现在我们来进一步学习汇编指令,加深对寄存器的印象。

寄存器,其实可以理解成系统规定名字的变量。在32位系统中,我们可以把寄存器理解成4个字节的无符号整形(unsigned int)变量。其实在内存的角度来看,所有数据都是以二进制保存的,之所以能展现出不同的内容,只不过是因为我们赋予了它们不同格式罢了。


MOV数据传送指令(move)

这个可以说是最最常见的赋值指令了,格式如下:

dst代表目标,src代表源,下面就不多解释了,大家习惯就好。可翻译成伪C代码 dst = src。

将src传送到dst,其中dst可以是地址,也可以是寄存器。而src可以是地址,可以是寄存器,也可以是立即数(也就是常数,写死的)。注意:dst不可以是立即数,src和dst不可以同时为地址,另外src和dst的数据长度必须相同(字节数相同)。例如:


MOVSX 符号填充指令(move sign-extends)

带符号的扩展传送指令格式如下:

MOVSX和MOV指令相似,也是将src传送给dst,只是src的数据长度要小于dst,不足位用src的符号来填充。例如:


MOVZX 零填充指令(move zero-extends)

零填充传送指令格式如下:

MOVZX和MOVSX指令相似,只不过不足位恒定用0来填充。例如:


XCHG 数据交换指令(exchanges)

将dst和src中的数据相互交换,dst和src可以是寄存器,可以是内存,但不可以同时为内存。例如:


LEA有效地址传送指令(load effect address)

这个指令在大多数情况下用作运算,因为其支持同时多种运算方式,格式如下:

[]是取值符号,与指针的*取值类似,而LEA又是取地址指令,所以实际上上面的指令翻译成伪C代码应该是dst = src。

将有效内存地址数值传送到寄存器,其中dst只能是寄存器。而src可以是寄存器,也可以是立即数。例如:


PUSH 数据入栈指令(push)

push指令多用于函数调用参数传递和环境保护,与pop天生一对。格式如下:

在寄存器介绍的时候我们已经知道ESP寄存器总是指向堆栈栈顶,而堆栈的使用是从高地址到低地址的。push指令首先会将esp减4(在32位系统下),再MOV [esp],src,例如:


POP 数据出栈指令(pop)

pop指令与push指令完全相反,格式如下:

需要注意的是,dst必须为寄存器。pop指令首先会执行MOV dst,[esp],再将esp加4(在32位系统下),例如:

内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: