初学汇编指令详解.pdfVIP

  1. 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
  2. 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  3. 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
  4. 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
  5. 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们
  6. 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
  7. 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
初学汇编指令详解

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、LOOPNE、CALL、RET、INT。 五、 串操作指令:MOVS、LODS、STOS、CMPS、SCAS。 六、 标志处理指令:CLC、STC、CLD、STD。 1、 MOV (传送) 指令写法:MOV target,source 功能描述:将源操作数source 的值复制到target 中去,source 值不变 注意事项:1)target 不能是CS (代码段寄存器),我的理解是代码段不可写,只可读,所 以相应这地方也不能对CS 执行复制操作。2)target 和source 不能同时为内存数、段寄存器 (CS\DS\ES\SS\FS\GS)3)不能将立即数传送给段寄存器4)target 和source 必须类型匹配, 比如,要么都是字节,要么都是字或者都是双字等。4)由于立即数没有明确的类型,所以 将立即数传送到target 时,系统会自动将立即数零扩展到与target 数的位数相同,再进行传 送。有时,需要用BYTE PTR 、WORD PTR、DWORD PTR 明确指出立即数的位数 写法示例:MOV dl,01H;MOV eax,[bp]; eax =ss:[bp] 双字传送。 2、 XCHG(交换) 指令写法:XCHG object1,object2 功能描述:交换object1 与object2 的值 注意事项:1)不能直接交换两个内存数的值2)类型必须匹配3)两个操作数任何一个都不 能是段寄存器 【看来段寄存器的写入的限制非常的严格,MOV 指令也不能对段寄存器进行 写入】,4)必须是通用寄存器 (ax、bx、cx、dx、si、di)或内存数 写法示例:XCHG ax,[bx][si]; XCHG ax,bx; 3、 LEA(装入有效地址) 指令写法:LEZ reg16,mem 功能描述:将有效地址MEM 的值装入到16 位的通用寄存器中。 写法示例:假定bx=5678H,EAX=1,EDX=2 Lea si,2[bx] ;si=567AH Lea di,2[eax][edx] ;di=5 注意,这里装入的是有效地址,并不是实际的内存中的数值,如果要想取内存中该地址对应 的数值,还需要加上段地址才行,而段地址有可能保存在DS 中,也有可能保存在SS 或者 CS 中哦:不知道我的理解可正确。。。。 4、 LDS\LES\LGS\LSS (注意,与LEA 不同的是,这里是装入的值,而不是有效地址) 这几个指令,名称不同,作用差不多。 写法:LDS reg16,mem32 功能描述:reg16 等于mem32 的低字,而DS 对应于mem32 的高字 (当为LES 时,这里就 是ES 对应于mem32 的高字) 用来给一个段寄存器和一个16 位通用寄存器同时复制。 注意事项:第一个操作数必须是16 位通用寄存器 在接着往下说之前,先熟悉下堆栈的概念。堆栈,位于内存的堆栈段中,是内存的一部分, 具有 “先进后出”的特点,堆栈只有一个入口,即当前栈顶,当堆栈为空时,栈顶和栈底指 向同一内存地址,在WINDOWS 中,可以把堆栈理解成一个倒着的啤酒瓶,上面的地址大, 下面的地址小,当从瓶口往啤酒瓶塞啤酒时 (进栈),栈顶就会往瓶口下移动,也就是往低 地址方向移动,同理,出栈时,正好相反,把啤酒给倒出来,栈顶向高地址方向移动。这就 是所谓的堆栈,哼哼,很Easy 吧。 在汇编语言中,堆栈操作的最小单位是字,也就是说,只能以字或双字为单位,同时,SS: SP 指向栈顶 (SS 为堆栈段寄存器,SP 为堆栈指针,二者一相加,就构成了堆栈栈顶的内存 地址)。 5、 PUSH (进栈) 写法:PUSH reg16 (32)/seg/mem16 (32)/imm 功能描述:将通用寄存器/段寄存器/内存数/立即数的值压入栈中,即: SP=SP-2 SS:[SP]=16 位数值 (当将32 位数值压入栈中时,SP=SP-4,SS:[

文档评论(0)

wnqwwy20 + 关注
实名认证
文档贡献者

该用户很懒,什么也没介绍

版权声明书
用户编号:7014141164000003

1亿VIP精品文档

相关文档