初学汇编指令详解

初学汇编指令详解

ID:38854940

大小:153.66 KB

页数:14页

时间:2019-06-20

初学汇编指令详解_第1页
初学汇编指令详解_第2页
初学汇编指令详解_第3页
初学汇编指令详解_第4页
初学汇编指令详解_第5页
资源描述:

《初学汇编指令详解》由会员上传分享,免费在线阅读,更多相关内容在行业资料-天天文库

1、80X86汇编过程中经常用到的一些汇编指令。从功能分类上来说,一共可分为一、数据传送指令:MOV、XCHG、LEA、LDS、LES、PUSH、POP、PUSHF、POPF、CBW、CWD、CWDE。二、算术指令:ADD、ADC、INC、SUB、SBB、DEC、CMP、MUL、DIV、DAA、DAS、AAA、AAS。三、逻辑指令:AND、OR、XOR、NOT、TEST、SHL、SAL、SHR、SAR、RCL、RCR、ROL、ROR。四、控制转移指令:JMP、Jcc、JCXZ、LOOP、LOOPZ、LOOPNZ、LO

2、OPNE、CALL、RET、INT。五、串操作指令:MOVS、LODS、STOS、CMPS、SCAS。六、标志处理指令:CLC、STC、CLD、STD。1、MOV(传送)指令写法:MOVtarget,source功能描述:将源操作数source的值复制到target中去,source值不变注意事项:1)target不能是CS(代码段寄存器),我的理解是代码段不可写,只可读,所以相应这地方也不能对CS执行复制操作。2)target和source不能同时为内存数、段寄存器(CSDSESSSFSGS)3)不能

3、将立即数传送给段寄存器4)target和source必须类型匹配,比如,要么都是字节,要么都是字或者都是双字等。4)由于立即数没有明确的类型,所以将立即数传送到target时,系统会自动将立即数零扩展到与target数的位数相同,再进行传送。有时,需要用BYTEPTR、WORDPTR、DWORDPTR明确指出立即数的位数写法示例:MOVdl,01H;MOVeax,[bp];eax=ss:[bp]双字传送。2、XCHG(交换)指令写法:XCHGobject1,object2功能描述:交换object1与object

4、2的值注意事项:1)不能直接交换两个内存数的值2)类型必须匹配3)两个操作数任何一个都不能是段寄存器【看来段寄存器的写入的限制非常的严格,MOV指令也不能对段寄存器进行写入】,4)必须是通用寄存器(ax、bx、cx、dx、si、di)或内存数写法示例:XCHGax,[bx][si];XCHGax,bx;3、LEA(装入有效地址)指令写法:LEZreg16,mem功能描述:将有效地址MEM的值装入到16位的通用寄存器中。写法示例:假定bx=5678H,EAX=1,EDX=2Leasi,2[bx];si=567AHL

5、eadi,2[eax][edx];di=5注意,这里装入的是有效地址,并不是实际的内存中的数值,如果要想取内存中该地址对应的数值,还需要加上段地址才行,而段地址有可能保存在DS中,也有可能保存在SS或者CS中哦:>不知道我的理解可正确。。。。4、LDSLESLGSLSS(注意,与LEA不同的是,这里是装入的值,而不是有效地址)这几个指令,名称不同,作用差不多。写法:LDSreg16,mem32功能描述:reg16等于mem32的低字,而DS对应于mem32的高字(当为LES时,这里就是ES对应于mem32的

6、高字)用来给一个段寄存器和一个16位通用寄存器同时复制。注意事项:第一个操作数必须是16位通用寄存器在接着往下说之前,先熟悉下堆栈的概念。堆栈,位于内存的堆栈段中,是内存的一部分,具有“先进后出”的特点,堆栈只有一个入口,即当前栈顶,当堆栈为空时,栈顶和栈底指向同一内存地址,在WINDOWS中,可以把堆栈理解成一个倒着的啤酒瓶,上面的地址大,下面的地址小,当从瓶口往啤酒瓶塞啤酒时(进栈),栈顶就会往瓶口下移动,也就是往低地址方向移动,同理,出栈时,正好相反,把啤酒给倒出来,栈顶向高地址方向移动。这就是所谓的堆栈,

7、哼哼,很Easy吧。在汇编语言中,堆栈操作的最小单位是字,也就是说,只能以字或双字为单位,同时,SS:SP指向栈顶(SS为堆栈段寄存器,SP为堆栈指针,二者一相加,就构成了堆栈栈顶的内存地址)。5、PUSH(进栈)写法:PUSHreg16(32)/seg/mem16(32)/imm功能描述:将通用寄存器/段寄存器/内存数/立即数的值压入栈中,即:SP=SP-2SS:[SP]=16位数值(当将32位数值压入栈中时,SP=SP-4,SS:[SP]=32为数值)6、POP(出栈)写法:POPreg16(32)/seg/

8、mem16(32)【不能出栈到CS中】功能描述:将堆栈口的16(32)位数据推出到通用寄存器/段寄存器/内存中,即:寄存器/段寄存器/内存=SS:[SP]SP=SP+2(当将32位数值出栈时,SP=SP+4)(注意,不能出栈给立即数哦,常量不可变嘛)7、PUSHA、PUSHAD、POPA、POPAD作用:将所有16/32位通用寄存器进栈/出栈如:PUSHA;将AX、CX、

当前文档最多预览五页,下载文档查看全文

此文档下载收益归作者所有

当前文档最多预览五页,下载文档查看全文
温馨提示:
1. 部分包含数学公式或PPT动画的文件,查看预览时可能会显示错乱或异常,文件下载后无此问题,请放心下载。
2. 本文档由用户上传,版权归属用户,天天文库负责整理代发布。如果您对本文档版权有争议请及时联系客服。
3. 下载前请仔细阅读文档内容,确认文档内容符合您的需求后进行下载,若出现内容与标题不符可向本站投诉处理。
4. 下载文档时可能由于网络波动等原因无法下载或下载错误,付费完成后未能成功下载的用户请联系客服处理。