词条 | 汇编语言 |
释义 | 汇编语言(AssemblyLanguage)是面向机器的程序设计语言。在汇编语合中,用助记符(Memoni)代替操作码,用地址符号(Symbol)或标号(Label)代替地址码。这样用符号代替机器语言的二进制码,就把机器语言变成了汇编语言。于是汇编语言亦称为符号语言。使用汇编语言编写的程序,机器不能直接识别,要由一种程序将汇编语言翻译成机器语言,这种起翻译作用的程序叫汇编程序,汇编程序是系统软件中语言处理系统软件。汇编程序把汇编语言翻译成机器语言的过程称为汇编。中国著名计算机科学教育家王爽写过一本名叫《汇编语言》的书。 相关教材(80x86汇编语言基础教程 汇编语言 新版汇编语言程序设计 汇编语言程序设计) 相关指令(数据传送指令 算术指令 逻辑指令 移位指令 循环移位指令 串处理指令 控制转移指令 过程调用及返回指令 中断指令 处理机控制指令 十进制调整指令) 词语解释huì biān 1.动词,把资料或文章等编辑在一起 2.名词,编辑在一起的资料,文献 3.名词,一种计算机语言 汇编简介汇编语言(Assembly Language)是面向机器的程序设计语言。 汇编语言比机器语言易于读写、易于调试和修改,同时也具有机器语言执行速度快,占内存空间少等优点,但在编写复杂程序时具有明显的局限性,汇编语言依赖于具体的机型,不能通用,也不能在不同机型之间移植。 是能完成一定任务的机器指令的集合。 常说汇编语言时,是低级语言,并不是说汇编语言要被弃之,相反,汇编语言仍然是程序员必须了解的语言,在某些行业与领域,汇编是必不可少的,非它不可适用。只是,现在计算机最大的领域为IT软件,也是我们常说的 Windows编程,在熟练的程序员手里,使用汇编语言编写的程序,运行效率与性能比其它语言写的程序是成倍的优秀,但是代价是需要更长的时间来优化,如果对计算机原理及编程基础不扎实,实在是得不偿失,对比现在的软件开发,已经是市场化的软件行业,加上高级语言的优秀与跨平台,一个公司不可以让一个团队使用汇编语言来编写所有的东西,花上几倍甚至几十倍的时间,不如使用其它语言来完成,只要最终结果不比汇编语言编写的差太多,就能抢先一步完成,这是市场经济下的必然结果。 但是,迄今为止,还没有程序员敢断定汇编语言是不需要学的,一个不懂汇编语言的程序员,只是三流的程序员,这是大部分人的共识,同时,技术汇编语言(Assembly Language)是面向机器的程序设计语言精湛的汇编程序员,已经脱离软件开发,挤身于工业电子编程中,一个电子工程师,主要开发语言就是汇编,c语言使用只占极少部分,而电子开发工程师是千金难求,在一些工业公司,一个核心的电子工程师比其它任何职员待遇都高,对比起来,一般电子工程师待遇是程序员的十倍以上。这种情况是因为现在学习汇编的人虽然也不少,但是真正能学到精通的却不多,它难学,难用,适用范围小,虽然简单,但是过于灵活,学习过高级语言的人去学习汇编比一开始学汇编的人难得多,但是学过汇编的人学习高级语言却很容易,简从繁易,繁从简难。 总之,汇编语言是程序员的必修语言。 目前国内最好的汇编网站是“AoGo汇编小站”。其站长aogo,就是一个在工业方面有所成就的工程师,有意者可多参考。 其次就是罗云彬的汇编站点:这个大概是国内建站时间最长的汇编站点,其编写的《Windows坏境下32位汇编语言程序设计》一书。是站长十几年的经验的集合,不妨看看。 熟悉指令,可以尝试破解,加强兴趣,参考看雪学院,国内最好的破解组织,其中看雪与众高手打造的破解书《加密 解密完全方案》非常有名。汇编语言是一种低级的程序语言可直接控制硬件。 汇编概况汇编语言是一种功能很强的程序设计语言,也是利用计算机所有硬件特性并能直接控制硬件的语言。汇编语言,作为一门语言,对应于高级语言的编译器,需要一个“汇编器”来把汇编语言原文件汇编成机器可执行的代码。高级的汇编器如MASM,TASM等等为我们写汇编程序提供了很多类似于高级语言的特征,比如结构化、抽象等。在这样的环境中编写的汇编程序,有很大一部分是面向汇编器的伪指令,已经类同于高级语言。现在的汇编环境已经如此高级,即使全部用汇编语言来编写Windows的应用程序也是可行的,但这不是汇编语言的长处。汇编语言的长处在于编写高效且需要对机器硬件精确控制的程序。 大多数情况下Linux程序员不需要使用汇编语言,因为即便是硬件驱动这样的底层程序在Linux操作系统中也可以完全用C语言来实现,再加上GCC这一优秀的编译器目前已经能够对最终生成的代码进行很好的优化,的确有足够的理由让我们可以暂时将汇编语言抛在一边了。但实际情况是Linux程序员有时还是需要使用汇编,或者不得不使用汇编,理由很简单:精简、高效和libc无关性。假设要移植Linux到某一特定的嵌入式硬件环境下,首先必然面临如何减少系统大小、提高执行效率等问题,此时或许只有汇编语言能帮上忙了。 优点汇编语言直接同计算机的底层软件甚至硬件进行交互,它具有如下一些优点: (1)能够直接访问与硬件相关的存储器或I/O端口; (2)能够不受编译器的限制,对生成的二进制代码进行完全的控制; (3)能够对关键代码进行更准确的控制,避免因线程共同访问或者硬件设备共享引起的死锁; (4)能够根据特定的应用对代码做最佳的优化,提高运行速度; (5)能够最大限度地发挥硬件的功能。 缺点同时还应该认识到,汇编语言是一种层次非常低的语言,它仅仅高于直接手工编写二进制的机器指令码,因此不可避免地存在一些缺点: (1)编写的代码非常难懂,不好维护; (2)很容易产生bug,难于调试; (3)只能针对特定的体系结构和处理器进行优化; (4)开发效率很低,时间长且单调。 特点汇编语言比机器语言易于读写、调试和修改,同时具有机器语言全部优点。但在编写复杂程序时,相对高级语言代码量较大,而且汇编语言依赖于具体的处理器体系结构,不能通用,因此不能直接在不同处理器体系结构之间移植。 汇编语言的特点: 1.面向机器的低级语言,通常是为特定的计算机或系列计算机专门设计的。 2.保持了机器语言的优点,具有直接和简捷的特点。 3.可有效地访问、控制计算机的各种硬件设备,如磁盘、存储器、CPU、I/O端口等。 4.目标代码简短,占用内存少,执行速度快,是高效的程序设计语言。 5.经常与高级语言配合使用,应用十分广泛。 对于不同型号的计算机,有着不同的结构的汇编语言 汇编语言由于采用了助记符号来编写程序,比用机器语言的二进制代码编程要方便些,在一定程度上简化了编程过程。汇编语言的特点是用符号代替了机器指令代码,而且助记符与指令代码一一对应,基本保留了机器语言的灵活性。使用汇编语言能面向机器并较好地发挥机器的特性,得到质量较高的程序。 汇编语言是面向具体机型的,它离不开具体计算机的指令系统,因此,对于不同型号的计算机,有着不同的结构的汇编语言,而且,对于同一问题所编制的汇编语言程序在不同种类的计算机间是互不相通的。 汇编语言中由于使用了助记符号,用汇编语言编制的程序输入计算机,计算机不能象用机器语言编写的程序一样直接识别和执行,必须通过预先放入计算机的"汇编程序"中进行加工和翻译,才能变成能够被计算机直接识别和处理的二进制代码程序。用汇编语言等非机器语言书写好的符号程序称为源程序,运行时汇编程序要将源程序翻译成目标程序。目标程序是机器语言程序,当它被安置在内存的预定位置上,就能被计算机的CPU处理和执行。 汇编语言像机器指令一样,是硬件操作的控制信息,因而仍然是面向机器的语言,使用起来还是比较繁琐费时,通用性也差。但是,汇编语言用来编制系统软件和过程控制软件,其目标程序占用内存空间少,运行速度快,有着高级语言不可替代的用途。 应用汇编语言作为最基本的编程语言之一,汇编语言虽然应用的范围不算很广,但重要性却勿庸置疑,因为它能够完成许多其它语言所无法完成的功能。就拿Linux内核来讲,虽然绝大部分代码是用C语言编写的,但仍然不可避免地在某些关键地方使用了汇编代码,其中主要是在Linux的启动部分。由于这部分代码与硬件的关系非常密切,即使是C语言也会有些力不从心,而汇编语言则能够很好扬长避短,最大限度地发挥硬件的性能。 1.70%以上的系统软件是用汇编语言编写的。 2.某些快速处理、位处理、访问硬件设备等高效程序是用汇编语言编写的。 3.某些高级绘图程序、视频游戏程序是用汇编语言编写的。 汇编语言是理解整个计算机系统的最佳起点和最有效途径,人们经常认为汇编语言的应用范围很小,而忽视它的重要性。其实汇编语言对每一个希望学习计算机科学与技术的人来说都是非常重要的,是不能不学习的语言。所有可编程计算机都向人们提供机器指令,通过机器指令人们能够使用机器的逻辑功能。所有程序,不论用何种语言编制,都必须转成机器指令,运用机器的逻辑功能,其功能才能得以实现。机器的逻辑功能,软件系统功能构筑其上,硬件系统功能运行于下。汇编语言直接描述机器指令,比机器指令容易记忆和理解。通过学习和使用汇编语言,能够感知、体会、理解机器的逻辑功能,向上为理解各种软件系统的原理,打下技术理论基础;向下为掌握硬件系统的原理,打下实践应用基础。学习汇编语言,向上可以理解软件,向下能够感知硬件,是我们理解整个计算机系统的最佳起点。 相关教材80x86汇编语言基础教程基本信息 《80X86汇编语言基础教程》 教材名称:80X86汇编语言基础教程 ISBN编号: 9787111253822 出版时间:2009-3-1 出版社: 机械工业出版社 页数: 213 版次印次: 1 作者: (美)德特默(Detmer,R.C.) 著,郑红,陈丽琼 译 开本: 16开 装帧: 平装 印数: 1 内容简介 学会一门具体的汇编语言对理解计算机体系结构是非常有益的,然而,许多关于计算机组成和体系结构的教材对这方面的知识介绍得不多。《80x86汇编语言基础教程(附光盘)》主要针对Intel 80x86体系结构介绍汇编语言知识,因此既是计算机组成和体系结构课程的很好的补充教材,同时也适合作为单独的汇编语言课程教材。通过《80x86汇编语言基础教程(附光盘)》的学习,学生能够使用微软的MASM汇编器来编译32位的平面存储模式程序,并在微软的Windbg调试器控制下跟踪程序指令的执行,从中了解计算机内部存储器和寄存器内容的变化。《80x86汇编语言基础教程(附光盘)》附带的软件包为编写和调试控制台应用程序提供了很好的环境。 汇编语言基本信息《汇编语言》 教材名称:汇编语言(第2版) ISBN编号: 9787302172284 出版时间: 2008-4-1 出版社: 清华大学出版社 页数: 337 版次印次: 2 作者: 王爽 著 开本: 16开 装帧: 平装 印数: 1 字数: 527000 内容简介 汇编语言是各种CPU提供的机器指令的助记符的集合,人们可以用汇编语言直接控制硬件系统进行工作。汇编语言是很多相关课程(如数据结构、操作系统、微机原理等)的重要基础。为了更好地引导、帮助读者学习汇编语言,作者以循序渐进的思想精心创作了这本书。本书具有如下特点:采用了全新的结构对课程的内容进行组织,对知识进行最小化分割,为读者构造了循序渐进的学习线索;在深入本质的层面上对汇编语言进行讲解;对关键环节进行深入的剖析。 本书可用作大学计算机专业本科生的汇编教材及希望深入学习计算机科学的读者的自学教材。 新版汇编语言程序设计基本信息 《新版汇编语言程序设计》 教材名称:新版汇编语言程序设计 ISBN编号: 9787121026966 出版时间: 2007-01-01 出版社: 电子工业出版社 作者: 钱晓捷 主编 装帧: 平装 字数: 563200 内容简介 本书以Intel 80x86指令系统和MASM 6.x为主体,全面而系统地介绍16/32位整数、浮点、多媒体指令的汇编语言程序设计方法。全书可分为基础和提高两部分。前5章作为基础部分,以当前“汇编语言程序设计”课程的教学为目标,为读者讲解16位基本整数指令及其汇编语言程序设计的知识。基础部分的主要内容是:汇编语言程序设计的基础知识,8086指令详解,MASM伪指令和操作符,程序格式,程序结构及其设计方法。后4章为提高部分,从不同的方面介绍汇编语言程序设计的深入内容和实际应用知识。提高部分各章的内容相对独立,主要有:32位80x86 CPU的整数指令系统及其编程,汇编语言与C/C++的混合编程,80x87 FPU的浮点指令系统及其编程,多媒体扩展指令系统及其编程,64位指令简介。本书可作为高等院校《汇编语言程序设计》课程的教材或参考书,主要读者为计算机及相关学科的本科和高职、高专学生。本书内容广博、语言浅显、结构清晰、实例丰富,也适合于电子、自动控制等专业的高校学生和成教学生,计算机应用开发人员,深入学习微机应用技术的普通读者等。 汇编语言程序设计基本信息《汇编语言程序设计》 产品名称:汇编语言程序设计 ISBN编号:9787111272601 出版时间:2009-10-1 出版社: 机械工业出版社 页数: 340 版次印次: 1 作者: 何超主编 开本: 16开 装帧: 平装 印数: 1 字数: 544000 内容简介 本书共8章,主要讨论汇编语言的编程基础、程序开发过程和调试方法。 本书的主要特点是通俗易懂,遵循由浅入深、由简到繁、循序渐进的原则。力争改变汇编语言难学难教的状况。与本书配套的《汇编语言程序设计实验与习题解答》一书另行出版,该书包含详尽的汇编语言程序设计实验和本书所有习题的解答。本书既可作为高等院校信息类(如计算机、自动控制、电工电子等)专业的本科教材,也可作为工程技术人员的参考书。 相关编译环境汇编的调试环境总的来说比较少,也很少有非常好的编译器。reallychenchi设计的轻松汇编是一款非常适合初学者的汇编编译器。轻松汇编是一个汇编语言集成开发环境,主要面向汇编语言初学者,也可以用它进行开发。除了普通的编辑功能以外,它还可以自动整理格式、高亮显示和编译、链接、调试汇编程序,非常方便实用。 轻松汇编的最大特点是可以格式整理,就像VC6.0一样,可以设置断点调试,省却了使用者的不少工作。它可以在Win98/2k/XP下运行,是一款很优秀的软件。 相关指令数据传送指令一 通用数据传送指令 指令 英文全拼 翻译 MOV Move 传送 PUSH Push onto the stack 进栈 POP Pop from the stack 出栈 XCHG Exchange 交换MOV指令为双操作数指令,两个操作数中不能全为内存操作数 格式:MOV DST,SRC 执行操作:dst = src 注:1.目的数可以是通用寄存器,存储单元和段寄存器(但不允许用CS段寄存器). 2.立即数不能直接送段寄存器 3.不允许在两个存储单元直接传送数据 4.不允许在两个段寄存器间直接传送信息 PUSH入栈指令及POP出栈指令: 堆栈操作是以“后进先出”的方式进行数据操作。 格式:PUSH SRC //Word 执行操作:(SP)<-(SP)-2 ((SP)+1,(SP))<-(SRC) 注:1.入栈的操作数除不允许用立即数外,可以为通用寄存器,段寄存器(全部)和存储器。 2.入栈时高位字节先入栈,低位字节后入栈。 格式:POP DST //Word 执行操作:(DST)<-((SP+1),(SP)) (SP)<-(SP)+2 注:1.出栈操作数除不允许用立即数和CS段寄存器外,可以为通用寄存器,段寄存器和存储器。 2.执行POP SS指令后,堆栈区在存储区的位置要改变。 3.执行POP SP 指令后,栈顶的位置要改变。 XCHG(eXCHanG)交换指令: 将两操作数值交换。 格式:XCHG OPR1,OPR2 //Byte/Word 执行的操作:(OPR1)<-->(OPR2) 注:1.必须有一个操作数是在寄存器中 2.不能与段寄存器交换数据 存储器与存储器之间不能交换数据。 二 累加器专用传送指令 指令 英文全拼 翻译 IN Input 输入 OUT Output 输出 XLAT Translate 换码IN 输入指令 长格式为:IN AL,PORT(字节) IN AX,PORT(字) 执行的操作:(AL)<-(PORT)(字节) (AX)<-(PORT+1,PORT)(字) 短格式为:IN AL,DX(字节) IN AX,DX(字) OUT 输出指令 长格式为:OUT PORT,AL(字节) OUT PORT,AX(字) 执行的操作:(PORT)<-(AL)(字节) (PORT+1,PORT)<-(AX)(字) 短格式为:OUT DX,AL(字节) OUT DX,AX(字) 执行的操作:((DX))<-(AL)(字节) ((DX)+1,(DX))<-AX(字) XLAT(TRANSLATE)换码指令: 把一种代码转换为另一种代码。 格式:XLAT (OPR 可选) //Byte 执行操作:(AL)<-((BX)+(AL)) 注:指令执行时只使用预先已存入BX中的表格首地址,执行后,AL中内容则是所要转换的代码。 三 有效地址送寄存器指令 指令 英文全拼 翻译 LEA Load effective address 有效地址送寄存器 LDS Load DS with Pointer 指针送寄存器和DS LES Load ES with Pointer 指针送寄存器和ESLEA(Load Effective Address) : 有效地址传送寄存器指令 格式:LEA REG,SRC //指令把源操作数SRC的有效地址送到指定的寄存器中。 执行操作:(REG)<-SRC 注:1. SRC只能是各种寻址方式的存储器操作数,REG只能是16位寄存器 2.MOV BX,OFFSET OPER_ONE 等价于LEA BX,OPER_ONE 3.MOV SP,[BX] //将BX间接寻址的相继的二个存储单元的内容送入SP中 4.LEA SP,[BX] //将BX的内容作为存储器有效地址送入SP中 LDS(Load DS with pointer): 指针送寄存器和DS指令 格式:LDS REG,SRC //常指定SI寄存器。 执行的操作:(REG)<-(SRC) (DS)<-(SRC+2) 注:把源操作数指定的4个相继字节送到由指令指定的寄存器及DS寄存器中。该指令常指定SI寄存器。 LES(Load ES with pointer) 指针送寄存器和ES指令 格式:LES REG,SRC //常指定DI寄存器 执行的操作:(REG)<-(SRC) (ES)<-(SRC+2)//与LDS大致相同,不同之处是将ES代替DS而已。 注:把源操作数指定的4个相继字节送到由指令指定的寄存器及ES寄存器中。该指令常指定DI寄存器。 四 标志寄存器传送指令 指令 英文全拼 翻译 LAHF Load AH with flags 标志送AH SAHF store AH into flags AH送标志寄存器 PUSHF push the flags 标志进栈 POPF pop the flags 标志出栈LAHF ( Load AH with Flags ) 标志位送AH指令 格式:LAHF ...... 执行操作:(AH)<-(PWS的低字节) 注:将PSW寄存器中的低8位的状态标志(条件码)送入AH的相应位,SF送D7位,ZF送D6位 SAHF( Store AH into Flags ) AH送标志寄存器指令 格式:SAHF 执行操作: (PWS的低字节)<-(AH) 注:将AH寄存器的相应位送到PSW寄存器的低8位的相应位,AH的D7位送SF,D6位送ZF。 PUSHF( PUSH the Flags) 标志进栈指令 格式:PUSHF 执行操作:(SP)<-(SP)-2 SP=SP-1,(SP)=PSW的高8位,SP=SP-1,(SP)=PSW的低8位 注:将标志寄存器的值压入堆栈顶部,同时栈指针SP值减2 POPF( POP the Flags ) 标志出栈指令 格式:POPF 执行操作:(PWS)<-((SP)+1,(SP)) (SP)<-(SP+2) PSW低8位=(SP),SP=SP+1,PSW高8位=(SP),SP=SP+1 注:与PUSHF相反,从堆栈的顶部弹出两个字节送到PSW寄存器中,同时堆栈指针值加2 算术指令一 加法指令 指令 英文全拼 翻译 ADD add 加法 ADC add with carry 带进位加法 INC increment 加1ADD(ADD)加法指令 格式:ADD DST,SRC //Byte/Word 执行操作: (DST)<-(SRC)+(DST) 注:1.两个存储器操作数不能通过ADD指令直接相加,即DST 和SRC必须有一个是通用寄存器操作数。 2.段寄存器不能作为SRC 和DST . 3.影响标志位Auxiliary Crray Flag,Carry Flag,Overflow Flag,Parity Flag,Sign Flag 和Zero Flag,如下所示: CF 根据最高有效位是否有进(借)位设置的:有进(借)位时CF=1,无进(借)位时CF=0. OF 根据操作数的符号及其变化来设置的:若两个操作数的符号相同,而结果的符号与之相反时OF=1,否则为0. ZF 根据结果来设置:不等于0时ZF=0,等于0时ZF=1 SF 根据结果的最高位来设置:最高位为0,则SF=0. AF 根据相加时D3是否向D4进(借)位来设置:有进(借)位时AF=1,无进(借)位时AF=0 PF 根据结果的1的个数时否为奇数来设置:1的个数为奇数时PF=0,为偶数时PF=1 ADC( ADd with Carry)带进位加法指令 格式:ADC DST,SRC //Byte/Word 执行操作: (DST)<-(SRC)+(DST)+CF 注:与ADD不同之处是还要加上进位标志位的值。 INC( INCrement) 加1指令 格式:INC OPR //Byte/Word 执行操作: (OPR)<-(OPR)+1 注:1.OPR可以是寄存器和存储器操作数,但不能是立即数和段寄存器 2.影响标志位OF,SF,ZF,PF 和AF,不影响CF. 二 减法指令 指令 英文全拼 翻译 SUB subtract 减法 SBB subtract with borrow 带借位减法 DEC Decrement 减1 NEG Negate 求补 CMP Compare 比较SUB( SUBtract ) 不带借位的减法指令 格式:SUB DST,SRC //Byte/Word 执行操作:(DST)<-(DST)-(SRC) 注:1.DST和SRC寻址方式及规定与ADD相同。 2.影响全部标志位。(判断标志位参见ADD) SBB ( SuBtract with Borrow) 带借位减法指令 格式:SBB DST,SRC //Byte/Word 执行操作:(DST)<-(DST)-(SRC)-CF DEC( DECrement ) 减1指令 格式:DEC OPR //Byte/Word 执行操作:(OPR)<-(OPR)-1//除CF标志位,其余标志位都受影响。 NEG( NEGate ) 求补指令 格式:NEG OPR 执行操作:(OPR)<- -(OPR) //将操作数按位求反后末位加1. CMP ( CoMPare ) 比较指令 格式:CMP OPR1,OPR2 执行操作:(OPR1)-(OPR2) //与SUB指令一样执行运算,但不保存结果。 注:该指令与SUB指令一样执行减法操作,但不保存结果,只是根据结果设置条件标志。 比较情况 无符号数 有符号数 A=B ZF=1 ZF=1 A>B CF=0 && ZF=0 SF^OF=0 && ZF=0 A<B CF=1 && ZF=0 SF^OF=1 && ZF=0 A>=B CF=0 || ZF=1 SF^OF=0 || ZF=1 A<=B CF=1 || ZF=1 SF^OF=1 || ZF=1 三 乘法指令 指令 英文全拼 翻译 MUL Unsigned Multiple 无符号数乘法 IMUL Signed Multiple 带符号数乘法MUL( unsigned MULtiple ) 无符号数乘法指令 格式:MUL SRC //Byte/Word . 执行操作:字操作:(AX)<-(AL)*(SRC) //字节运算时目的操作数用AL,乘积放在AX中 字节操作: (DX,AX)<-(AX)*(SRC) //字运算时目的操作数用AX,DX存放乘积的高位字,AX放乘积的低位字 注:1.目的数必须是累加器AX 或AL,指令中不需写出 源操作数SRC可以是通用寄存器和各种寻址方式的存储器操作数,而绝对不允许是立即数或段寄存器。 IMUL(sIgned MULtiple) 有符号数乘法指令 格式:IMUL SRC //与MUL指令相同,但必须是带符号数 四 除法指令 指令 英文全拼 翻译 DIV Unsigned divide 无符号数除法 IDIV Signed divide 带符号数除法 CBW Convert byte to word 字节转换为字 CWD Contert word to double word 字转换为双字DIV ( unsigned DIVide) 无符号数除法指令 格式:DIV SRC //Byte/Word 其中:SRC的规定同乘法指令MUL 执行操作:字节操作:(AL)<-(AX)/(SRC)的商 (AH)<-(AX)/(SRC)的余数 字操作:(AX)<-(DX,AX)/(SRC)的商 (DX)<-(DX,AX)/(SRC)的余数 注:存储器操作数必须指明数据类型:BYTE PTR src 或WORD PTR src IDIV (sIgned DIVied) 有符号数除法指令 格式:IDIV SRC 执行的操作:与DIV相同,但操作数必须是带符号数,商和余数也均为带符号数,且余数的符号与被除数的符号相同。 CBW(Convert Byte to Word) 字节转换为字指令 格式:CBW 执行操作:AL中的符号位(D7)扩展到8位AH中,若AL中的D7=0,则AH=00H,若AL中的D7=1,则AH=FFH. CWD(Convert Word to Double word) 字转换为双字指令 格式:CWD 执行操作:AX中的符号位(D15)扩展到16位DX中,若AX中的D15=0,则DX=0000H,若AX中的D15=1,则DX=FFFFH 注:这两条指令都不影响条件码。 逻辑指令一逻辑运算指令 指令 英文全拼 翻译 AND and 逻辑与 OR or 逻辑或 NOT not 逻辑非 XOR exclusive or 异或 TEST test 测试AND,OR,XOR和 TEST都是双字节操作指令,操作数的寻址方式的规定与算术运算指令相同。 NOT是单字节操作指令,不允许使用立即数。 逻辑运算均是按位进行操作,真值表如下: AND (位与&) OR ( 位或| ) XOR ( 位异或^ ) 1& 1 = 1 1 | 1 = 1 1 ^ 1 = 0 1 & 0 = 0 1 | 0 = 1 1 ^ 0 = 1 0 & 1 = 0 0 | 1 = 1 0 ^ 1 = 1 0 & 0 = 0 0 | 0 = 0 0 ^ 0 = 0AND(and) 逻辑与指令 格式:AND DST,SRC //Byte/Word 执行操作:(DST)<-(DST)^(SRC) 注:1.AND指令执行后,将使CF=0,OF=0,AF位无定义,指令执行结果影响SF,ZF和PF标志位。 2.AND指令典型用法A:用于屏蔽某些位,即使某些位为0. 例子:屏蔽AL的高4位:即将高4位和0000B相与,低4位和1111B相与 MOV AL,39H //AL= 0011 1001B[39H] ADD AL,0FH // AL= 0000 1001B[09H] 即0011 1001B[39H] & 0000 1111B[0FH] = 0000 1001B[09H] AND指令典型用法B:取出某一位的值(见TEST) OR(or) 逻辑或指令 格式:OR DST,SRC //Byte/Word 执行操作:(DST)<-(DST) | (SRC) 注:1.OR指令执行后,将使CF=0,OF=0,AF位无定义,指令执行结果影响SF,ZF和PF标志位。 2.常用于将某些位置1. 例子:将AL的第5位置1: MOV AL,4AH // AL=0100 1010B[4AH] OR AL,10H // AL=0101 1010B[5AH] 即0100 1010B[4AH] | 0001 0000B[10H] =0101 1010B [5AH] XOR(eXclusive OR) 逻辑异或指令 格式:XOR DST,SRC //Byte/Word 执行操作:(DST)<-(DST)^(SRC) 注:1.XOR指令常用于使某个操作数清零,同时使CF=0,清除进位标志。 2.XOR指令使某些位维持不变则与'0' 相异或,若要使某些位取反则与'1'相异或。 例子:将AL的高4位维持不变,低4位取反: MOV AL,B8H //AL=1011 1000B[B8H] XOR AL,0FH //AL=1011 0111B[B7H] 即1011 1000B[B8H] ^ 0000 1111[0FH]=1011 0111B[B7H] 例子:测试某一个操作数是否与另一确定操作数相等: XOR AX,042EH JZ .... //如果AX==042EH,则ZF=TRUE(1),执行JZ... NOT (not) 逻辑非指令 格式:NOT OPR //Byte/Word 执行操作:(OPR)<~(OPR) // ~ 01100101 [65H] =10011010 [9AH] 1.操作数不能使用立即数或段寄存器操作数,可使用通用寄存器和各种方式寻址的存储器操作数。 2.NOT指令不影响任何标志位。 例子:将AL各位取反: MOV AL,65H //AL=0110 0101B[65H] NOT AL //AL=1001 1010B[9AH] 即~ 0110 0101B[65H]=1001 1010B[9AH] TEST(test) 指令 格式:TEST OPR1,OPR2 //Byte/Word 执行操作:opr1 & opr2 注:1.两个操作数相与的结果不保存,结果影响标志位PF,SF和ZF,使CF=0,OF=0,而AF位无定义。 2.TEST指令常用于在不改变原有的操作数的情况下,检测某一位或某几位的条件是否满足。只要令用来测试的操作数对应检测位为1,其余位为0,相与后判断零标志ZF值的真假。 例:检测某位是否为1: 令用来测试的操作数对应检测位为1,其余位为0,TEST指令后,若该位为1则JNZ... TEST AL,0000 00001B //测试AL最低位是否为1:: 令用来测试的操作数对应检测位为1,其余位为0,执行TEST指令 JNZ THER //最低位若为1,则ZF=FALSE(0),执行JNZ THER,否则执行下一条指令。 或者:先对操作数求反,令用来测试的操作数对应检测位为1,其余位为0,TEST指令后,若该位为1则JZ... MOV DL,AL //将AL 传送到DL,主要是不要影响AL的值。 以下测试AL的b2位是否为1 NOT DL //先对操作数求反 TEST 0000 0100B //令用来测试的操作数对应检测位为1,其余位为0,执行TEST指令 JZ THER //若AL的b2位为1,则ZF=TRUE(1),执行JZ THER B:移位指令[所有的移位指令都影响标志位CF、OF、PF、SF和ZF、AF无定义。] 非循环逻辑移位:把操作数看成无符数来进行移位。 移位指令指令 英文全拼 翻译 SHL shift logical left 逻辑左移 SAL shift arithmetic left 算术左移 SHR shift logical right 逻辑右移 SAR shift arithmetic right 算术右移 ROL Rotate left 循环左移 ROR Rotate right 循环右移 RCL Rotate left through carry 带进位循环左移 RCR Rotate right through carry 带进位循环右移SHL( SHift logical Left )逻辑左移指令 格式:SHL OPR,CNT //Byte/Word 执行操作:使OPR左移CNT位,并使最低CNT位为全0. 1.OPR操作数不能使用立即数或段寄存器操作数,可使用通用寄存器和各种方式寻址的存储器操作数。 2.移位次数由CNT决定。每次将OPR的最高位移出并移到CF,最低位补0. MOV CL,7 //若移位多次,先预置移位次数CL SHL DX,CL //CNT可取1或CL寄存器操作数 SHR(SHift logical Right) 逻辑右移指令 格式:SHR OPR,CNT //Byte/Word 执行操作:同SHL,每次将OPR的最低位D0移出并移到CF.最高位补0. 非循环算术移位:将操作数看成有符号数来进行移位。 SAL(Shift Arithmetic Left) 算术左移指令 格式:SAL OPR,CNT //Byte/Word 执行操作:SAL指令与SHL指令完全相同 SAR(Shift Arithmetic Right) 算术右移指令 格式:SAR OPR,CNT //Byte/Word 执行操作:SAR指令每次移位时,将最高位移入次高位的同时最高位值不变,最低位D0移出并移到CF. 循环移位指令ROL( ROtate Left) 循环左移指令 格式:ROL OPR,CNT //Byte/Word 执行操作:每次移位时,最高位移出并同时移到CF和最低位D0. ROR (ROtate Right)循环右移指令 格式:ROR OPR,CNT //Byte/Word 执行操作:每次移位时,最低位D0移出并同时移到CF和最高。 带进位循环移位指令 RCL(Rotate Left through Carry)带进位循环左移指令 格式:RCL OPR,CNT //Byte/Word RCR (Rotate Right through Carry)带进位循环右移指令 格式:RCR OPR,CNT //Byte/Word 串处理指令一 与REP相配合工作的MOVS,STOS和LODS指令 指令 英文全拼 翻译 REP repeat 重复操作 MOVS MOVe String 串传送指令 STOS STOre into String 存入串指令 LODS LOaD from String 从串取指令 CLD Clear direction flag 使地址自动增量 STD Set direction flag 使地址自动减量REP(REPeat)重复操作前缀 格式:REP String Primitive 执行的操作: 1)如(CX)=0则退出REP,否则往下执行。 2)(CX)<-(CX)-1 3)执行其中的串操作 4)重复1)~3) 注:其中String Primitive可为MOVS,LODS或STOS指令 MOVS 串传送指令 格式:MOVS ES:BYTE PTR[DI],DS:[SI] 可有三种 MOVS DST,SRC MOVSB//字节串传送DF=0,SI = SI + 1,DI = DI + 1 ;DF = 1,SI = SI - 1,DI = DI MOVSW//字串传送DF=0,SI = SI + 2,DI = DI + 2 ;DF = 1,SI = SI - 2,DI = DI - 2 MOVSD//双字串传送DF=0,SI = SI + 4,DI = DI + 4 ;DF = 1,SI = SI - 4,DI = DI - 4 MOVSX//符号传送 MOVZX//零传送 执行的操作: 1)如(CX)=0则退出REP,否则往下执行。 2)(CX)<-(CX)-1 3)执行其中的串操作 4)重复1)~3) .MOVS 串传送指令 注:当方向标志DF=1时用,其中第二、三种格式明确地注明是传送字节或字,第一种格式则应在操作数中表明是字还是字节操作,例如: 1)((DI))<-((SI)) 2)字节操作: (SI)<-(SI)+(或-)1,(DI)<-(DI)+(或-)1//当方向标志DF=0时用 3)字操作: (SI)<-(SI)+(或-)2,(DI)<-(DI)+(或-)2当方向标志DF=0时用//当方向标志DF=1时用 该指令不影响条件码。 STOS(STOre into String) 存入串指令 格式:STOS DST STOSB //存放字节串( DI ) = AL STOSW //存放字串( DI ) = AX 执行操作:把AL或AX中的内容存放由DI指定的附加段的字节或字单元中,并根据DF值修改及数据类型修改DI的内容。 字节操作:((DT))←(AL),(DI)←(DI)±1 字操作:((DI))←(AX),(DI)←(DI)±2 注:1.在执行该指令之前,必须把要存入的数据预先存入AX或AL中,必须预置DI的初值。 2.DI所指向的存储单元只能在附加段中,即必须是ES:[DI] 3.该指令把AL或AX的内容存入由(DI)指定的附加段的某单元中,并根据DF的值及数据类型修改DI的内容,当它与REP联用时,可把AL或AX的内容存入一个长度为(CX)的缓冲区中。 LODS ( LOaD from String ) 从串取指令 格式:LODS SRC LODSB //从字节串取AL=(SI) LODSW //从字串取AX= (SI±1) (SI) 执行操作:字节操作:(AL)<-((SI)),(SI)<-(SI)+-1 字操作:(AX)<-((SI)),(SI)<-(SI)+-2 把由SI指定的数据段中字节或字单元的内容送入AL或AX中,并根据DF值及数据类型修改SI的内容。 注:1.在执行该指令之前,要取的数据必须在存储器中预先定义(用DB或DW),必须预置SI的初值。 2.源串允许使用段超越前缀来改变数据存储的段区。 3.该指令把由(SI)指定的数据段中某单元的内容送到AL或AX中,并根据方向标志及数据类型修改SI的内容。指令允许使用段跨越前缀来指定非数据段的存储区。该指令也不影响条件码。 4.一般说来,该指令不和REP联用。有时缓冲区中的一串字符需要逐次取出来测试时,可使用本指令。 CLD(CLear Direction flag) 清除方向标志指令 格式:CLD 执行操作:令DF=0,其后[SI],[DI]执行增量操作 该指令使DF=0,在执行串操作指令时可使地址自动增量 STD(SeT Direction flag) 设置方向标志指令 格式:STD 执行操作:令DF=1,其后[SI],[DI]执行减量操作 该指令使DF=1,在执行串操作指令时可使地址自动减量。 二与REPE/REPZ和REPNZ/REPNE联合工作的CMPS和SCAS指令 指令 英文全拼 翻译 REPE/REPZ Repeat Equal to Zero 等于零时重复操作 REPNE/REPNZ Repeat Not Equal to Zero 不等于零时重复操作 CMPS CoMPare String 串比较指令 SCAS SCAn String 串扫描指令 .REPE/REPZ 当相等/为零时重复串操作 格式:REPE(或REPZ) String Primitive 其中String Primitive可为CMPS或SCAS指令。 执行的操作: 1)如(CX)=0或ZF=0(即某次比较的结果两个操作数不等)时退出,否则往下执行 2)(CX)<-(CX)-1 3)执行其后的串指令 4)重复1)~3) REPNE/REPNZ 当不相等/不为零时重复串操作 格式:REPNE(或REPNZ) String Primitive 其中String Primitive可为CMPS或SCAS指令 执行的操作: 除退出条件(CX=0)或ZF=1外,其他操作与REPE完全相同。 CMPS(CoMPare String) 串比较指令 格式:CMPS SRC,DST CMPSB //字节串比较(SI)-(DI) CMPSW //字串比较(SI+1)(SI) - (DI+1)(DI) 执行操作:把由SI指向的数据段中的一个字节或字与由DI指向的附加段中的一个字节或字相减,不保留结果,只根据结果置标志位。 1)((SI))-((DI)) 2)字节操作:(SI)<-(SI)+-1,(DI)<-(DI)+-1 字操作:(SI)<-(SI)+-2,(DI)<-(DI)+-2 注:指令把由(SI)指向的数据段中的一个字(或字节)与由(DI)指向的附加段中的一个字(或字节)相减,但不保存结果,只根据结果设置条件码,指令的其它特性和MOVS指令的规定相同。 SCAS (SCAn String ) 串扫描指令 格式:SCAS DST SCASB SCASW 执行操作:把AX或AL的内容与由DI指向的在附加段中的一个字节或字相减,不保留结果,根据结果置标志位。 字节操作:(AL)-((DI)),(DI)<-(DI)+-1 字操作:(AL)-((DI)),(DI)<-(DI)+-2 注:该指令把AL(或AX)的内容与由(DI)指定的在附加段中的一个字节(或字)进行比较,并不保存结果,只根据结果置条件码。指令的其他特性和MOVS的规定相同。 控制转移指令一 JMP ( JuMP ) 无条件转移指令 名称 格式 执行操作 段内直接短跳转 JMP SHORT OPR IP=IP+8 位偏移量 段内直接近转移 JMP NEAR PTR OPR IP=IP+16位偏移量 段内间接转移 JMP WORD PTR OPR IP=(EA) 段间直接转移 JMP FAR PTR OPR IP=OPR 偏移地址,CS=OPR 段地址 段间间接转移 JMP DWORD PTR OPR IP=(EA),CS=(EA+2) 1)段内直接短转移 格式:JMP SHORT OPR 执行的操作:(IP)<-(IP)+8位位移量 2)段内直接近转移 格式:JMP NEAR PTR OPR 执行的操作:(IP)<-(IP)+16位位移量 3)段内间接转移 格式:JMP WORD PTR OPR 执行的操作:(IP)<-(EA) 4)段间直接(远)转移 格式:JMP FAR PTR OPR 执行的操作:(IP)<-OPR的段内偏移地址 (CS)<-OPR所在段的段地址 5)段间间接转移 格式:JMP DWORD PTR OPR 执行的操作:(IP)<-(EA) (CS)<-(EA+2) 1.无条件转移到指定的地址去执行从该地址开始的指令。 2.段内转移是指在同一代码段的范围内进行转移,只需改变IP寄存器内容。 3.段间转移则要转移到另一个代码段执行程序,此时要改变IP寄存器和CS段寄存器的内容。 二 条件转移指令: 指令 英文全拼 翻译 JZ/JE Jump if not zero,or not equal 结果不为零(或不相等)则转移 JNZ/JNE Jump if not zero,or not equal 结果不为零(或不相等)则转移 JS Jump if sign 结果为负则转移 JNS Jump if not sign 结果为正则转移 JO Jump if overflow 溢出则转移 JNO Jump if not overflow 不溢出则转移 JP/JPE Jump if parity,or parity even 奇偶位为1则转移 JNP/ JPO Jump if not parity,or parity odd 奇偶位为0则转移 JB/JNAE/JC Jump if below,or not above or equal,or carry 低于,或者不高于或等于,或进位位为1则转移 JNB/JAE/JNC Jump if not below,or above or equal,or not carry 不低于,或者高于或者等于,或进位位为0则转移 根据上一条指令所设置的条件码(标志位)来判断测试条件。 JZ(或JE)(Jump if zero,or equal) 结果为零(或相等)则转移 格式:JE(或JZ) OPR 测试条件:ZF=1 JNZ(或JNE)(Jump if not zero,or not equal) 结果不为零(或不相等)则转移 格式:JNZ(或JNE) OPR 测试条件:ZF=0 JS(Jump if sign) 结果为负则转移 格式:JS OPR 测试条件:SF=1 JNS(Jump if not sign) 结果为正则转移 格式:JNS OPR 测试条件:SF=0 JO(Jump if overflow) 溢出则转移 格式:JO OPR 测试条件:OF=1 JNO(Jump if not overflow) 不溢出则转移 格式:JNO OPR 测试条件:OF=0 JP(或JPE)(Jump if parity,or parity even) 奇偶位为1则转移 格式:JP OPR 测试条件:PF=1 JNP(或JPO)(Jump if not parity,or parity odd) 奇偶位为0则转移 格式:JNP(或JPO) OPR 测试条件:PF=0 JB(或JNAE,JC)(Jump if below,or not above or equal,or carry) 低于,或者不高于或等于,或进位位为1则转移 格式:JB(或JNAE,JC) OPR 测试条件:CF=1 . JNB(或JAE,JNC)(Jump if not below,or above or equal,or not carry) 不低于,或者高于或者等于,或进位位为0则转移 格式:JNB(或JAE,JNC) OPR 测试条件:CF=0 2)比较两个无符号数,并根据比较的结果转移 JB(或JNAE,JC) 格式:同上 JNB(或JAE,JNC) 格式:同上 JBE(或JNA)(Jump if below or equal,or not above) 低于或等于,或不高于则转移 格式:JBE(或JNA) OPR 测试条件:CFVZF=1 JNBE(或JA)(Jump if not below or equal,or above) 不低于或等于,或者高于则转移 格式:JNBE(或JA) OPR 测试条件:CFVZF=0 根据五个标志位:ZF、SF、OF、PF、CF的两种状态(0 FALSE或1 TRUE)产生10种测试条件。 名称 简写 格式 Flag == TRUE [1] Flag ==FALSE [ 0] Zero Falg ZF JE/JZOPR 结果为零转移JNE/JNZOPR 结果不为零转移 Sign Falg SF JS OPR 结果为负转移JNSOPR 结果为正转移 Overflow Flag OF JO OPR 溢出转移JNOOPR 不溢出转移 Parity Flag PF JP/JPE OPR 结果为偶转移 JNP/JPOOPR 结果为奇转移 Carry Flag CF JC OPR 有进位转移 JNCOPR 无进位转移 情况 指令 满足条件 指令 满足条件 A < B JC CF==1 JL SF^OF==1&& ZF==0 A ≥ B JNC CF==0 JNL SF^OF==0 || ZF==1 A ≤ B JNA CF==1 || ZF==1 JLG SF^OF==1 || ZF==1 A > B JA CF==0 && ZF==0 JG SF^OF==0 && ZF==0 三 比较两个无符号数,并根据比较的结果转移 指令 英文全拼 翻译 JB/JNAE/JC Jump if less,or not greater or equal 小于,或者不大于或者等于则转移 JNB/JAE/JNC Jump if not less,or greater or equal 不小于,或者大于或者等于则转移 JBE/JNA Jump if below or equal,or not above 低于或等于,或不高于则转移 JNBE/JA Jump if not below or equal,or above 不低于或等于,或者高于则转移JB(或JNAE,JC) 格式:同上 .JNB(或JAE,JNC) 格式:同上 JBE(或JNA)(Jump if below or equal,or not above) 低于或等于,或不高于则转移 格式:JBE(或JNA) OPR 测试条件:CFVZF=1 .JNBE(或JA)(Jump if not below or equal,or above) 不低于或等于,或者高于则转移 格式:JNBE(或JA) OPR 测试条件:CFVZF=0 四 比较两个带符号数,并根据比较的结果转移 指令 英文全拼 翻译 JL/LNGE Jump if less,or not greater or equal 小于,或者不大于或者等于则转移 JNL/JGE Jump if not less,or greater or equal 不小于,或者大于或者等于则转移 JLE/JNG Jump if less or equal,or not greater 小于或等于,或者不大于则转移 JNLE/JG Jump if not less or equal,or greater 不小于或等于,或者大于则转移JL(或LNGE)(Jump if less,or not greater or equal) 小于,或者不大于或者等于则转移 格式:JL(或JNGE) OPR 测试条件:SFVOF=1 JNL(或JGE)(Jump if not less,or greater or equal)不小于,或者大于或者等于则转移 格式:JNL(或JGE) OPR 测试条件:SFVOF=0 JLE(或JNG)(Jump if less or equal,or not greater) 小于或等于,或者不大于则转移 格式:JLE(或JNG) OPR 测试条件:(SFVOF)VZF=1 JNLE(或JG)(Jump if not less or equal,or greater) 不小于或等于,或者大于则转移 格式:JNLE(或JG) OPR 测试条件:(SFVOF)VZF=0 五 测试CX的值为0则转移指令 JCXZ(Jump if CX register is zero) CX寄存器的内容为零则转移 格式:JCXZ OPR//CX==0时转移 测试条件:(CX)=0 注:条件转移全为8位短跳! 六 循环指令 LOOP(LOOP)循环指令 格式:LOOP OPR 测试条件:CX ≠ 0 //OPR在程序中实际是个标号 LOOPNZ/LOOPNE 当不为零或不相等时循环指令 格式:LOOPNZ(或LOOPNE) OPR 测试条件:(CX)<>0且ZF=0 注:这三条指令的步骤是: 1)(CX)<-(CX)-1 2)检查是否满足测试条件,如满足则(IP)<-(IP)+D8的符号扩充。 过程调用及返回指令CALL(CALL) 过程调用指令 格式:CALL DST //DST在程序中实际是子程序标号 执行操作:先将过程的返回地址(即CALL的下一条指令的首地址)存入堆栈,然后转移到过程入口地址执行子程序。 调用方式 格式 断点保护入栈情况 过程入口地址 段内直接 CALL NEAR PTR PR1 (SP-1)(SP-2)←IP,CS不进栈CS值保持不变 IP←DST 段内间接 CALL WORD PTR (EA) (SP-1)(SP-2)←IP,CS不进栈CS值保持不变 IP←(EA) 段间直接 CALL FAR PTR PR1 (SP-1)(SP-2)←CS,(SP-3)(SP-4)←IP IP←DST偏移地址CS←DST段地址 段间间接 CALL DWORD PTR (EA) (SP-1)(SP-2)←CS,(SP-3)(SP-4)←IP IP←(EA),CS←(EA+2) 注:为了表明是段内调用,可使用NEAR PTR属性操作符作说明。 RET(RETurn)子程序返回指令 格式:RET RET EXP //带立即数返回 注:子程序返回指令RET放在子程序末尾,它使子程序在执行完全部任务后返回主程序继续执行被打断后的程序。返回地址在子程序调用时入栈保存的断点地址-IP或IP和CS. 中断指令INT指令 格式:INT TYPE 或INT 执行的操作:(SP)<-(SP)-2 ((SP)+1,(SP))<-(PSW) (SP)<-(SP)-2 ((SP)+1,(SP))<-(CS) (SP)<-(SP)-2 ((SP)+1,(SP))<-(IP) (IP)<-(TYPE*4) (CS)<-(TYPE*4+2) . INTO 若溢出则中断 执行的操作:若OF=1则: (SP)<-(SP)-2 ((SP)+1,(SP))<-(PSW) (SP)<-(SP)-2 ((SP)+1,(SP))<-(CS) (SP)<-(SP)-2 ((SP)+1,(SP))<-(IP) (IP)<-(10H) (CS)<-(12H) IRET 从中断返回指令 格式:IRET 执行的操作:(IP)<-((SP)+1,(SP)) (SP)<-(SP)+2 (CS)<-((SP)+1,(SP)) (SP)<-(SP)+2 (PSW)<-((SP)+1,(SP)) (SP)<-(SP)+2 处理机控制指令一标志处理指令 指令 英文全拼 翻译 CLC Clear carry 进位位置0指令 CF<-0 CMC Complement carry 进位位求反指令 CF<-CF STC Set carry 进位位置1指令 CF<-1 CLD Clear direction 方向标志置0指令 DF<-0 STD Set direction 方向标志置1指令 DF<-1 CLI Clear interrupt 中断标志置0指令 IF<-0 STI Set interrupt 中断标志置1指令 IF<-0二其他处理机控制指令 指令 英文全拼 翻译 NOP No Opreation 无操作 HLT Halt 停机 WAIT Wait 等待 ESC Escape 换码 LOCK Lock 封锁 处理器控制指令 CLC(CLear Carry) 进位位置0指令 格式:CLC //执行操作后,CF=0 CMC(CoMplement Carry) 进位位求反指令 格式:CMC //执行操作后,CF=!CF STC (SeT Carry) 进位位置1指令 格式:STC //执行操作后,CF=1 HLT (HaLT) 停机指令 格式:HLT 执行操作:使机器暂停工作,使处理器CPU处于停机状态,以等待一次外部中断到来,中断结束后,程序继续执行,CPU继续工作。 注:该指令可使机器暂停工作,使处理机处于停机状态以便等待一次外部中断到来,中断结束后可继续执行下面的程序。 NOP(No Operetion) 无操作指令 格式:NOP //此指令不执行任何操作,其机器码占一个字节单元 该指令不执行任何操作,其机器码占有一个字节,在调试程序时往往用这条指令占有一定的存储单元,以便在正式运行时用其他指令取代。 WAIT等待指令 该指令使处理机处于空转状态,它也可以用来等待外部中断的发生,但中断结束后仍返回WAIT指令继续执行。 ESC换码指令 格式ESC mem 其中mem指出一个存储单元,ESC指令把该存储单元的内容送到数据总线去。当然ESC指令不允许使用立即数和寄存器寻址方式。这条指令在使用协处理机(Coprocessor)执行某些操作时,可从存储器指得指令或操作数。协处理机(如8087)则是为了提高速度而可以选配的硬件。 .LOCK封锁指令 该指令是一种前缀,它可与其他指令联合,用来维持总线的锁存信号直到与其联合的指令执行完为止。当CPU与其他处理机协同工作时,该指令可避免破坏有用信息。 十进制调整指令当计算机进行计算时,必须先把十进制数转换为二进制数,再进行二进制数运算,最后将结果又转换为十进制数输出。 在计算机中,可用4位二进制数表示一位十进制数,这种代码称为BCD ( Binary Coded Decimal ). BCD码又称8421码,在PC机中,BCD码可用压缩的BCD码和非压缩的BCD码两种格式表示。 压缩的BCD码用4位二进制数表示一个十制数,整个十进数形式为一个顺序的以4位为一组的数串。 非压缩的BCD码以8位为一组表示一个十进制数,8位中的低4位表示8421的BCD码,而高4位则没有意义。 指令 英文全拼 翻译 DAA Decimal Adjust for Addition 加法的十进制调整指令 DAS Decimal Adjust for Subtraction 减法的十进制调整指令 AAA ASCII Adjust for Addition 加法的ASCII调整指令 AAS ASCII Adjust for Subtraction 减法的ASCII调整指令DAA(Decimal Adjust for Addition) 加法的十进制调整指令 格式:DAA 执行操作:执行之前必须先执行ADD或ADC指令,加法指令必须把两个压缩的BCD码相加,并把结果存话在AL寄存器中。 DAS(Decimal Adjust for Subtraction) 减法的十进制调整指令 格式:DAS 执行操作:执行之前必须先执行SUB或SBB指令,减法指令必须把两个压缩的BCD码相减,并氢结果存放在AL寄存器中。 非压缩的BCD码调整指令 AAA(ASCII Adjust for Addition) 加法的ASCII调整指令 格式:AAA 执行操作:执行之前必须先执行ADD或ADC指令,加法指令必须把两个非压缩的BCD码相加,并把结果存话在AL寄存器中。 AAS(ASCII Adjust for Subtraction) 减法的ASCII调整指令 格式:AAS 执行操作:执行之前必须先执行SUB或SBB指令,减法指令必须把两个非压缩的BCD码相减,并氢结果存放在AL寄存器中。 执行操作:[DI] = [SI],将位于DS段的由SI所指出的存储单元的字节或字传送到位于ES段的由DI 所指出的存储单元,再修改SI和DI,从而指向下一个元素。 在执行该指令之前,必须预置SI和DI的初值,用STD或CLD设置DF值。 格式:MOVS DST,SRC //同上,不常用,DST和SRC只是用来用类型检查,并不允许使用其它寻址方式来确定操作数。 1.目的串必须在附加段中,即必须是ES:[DI] 2.源串允许使用段跨越前缀来修饰,但偏移地址必须是[SI]. |
随便看 |
百科全书收录4421916条中文百科知识,基本涵盖了大多数领域的百科知识,是一部内容开放、自由的电子版百科全书。