汇编语言常用指令(汇编指令详解)
本文目录
- 汇编指令详解
- 汇编语言中的cld是什么指令
- 主要的汇编指令有哪些啊
- 汇编语言的几个简单指令,并附上中文解释
- 汇编语言中JB,JA,是什么意思
- 汇编语言常用指令
- 汇编语言中的jb是什么意思
- 汇编语言org指令怎么用
- 汇编语言中CMP是什么意思
- 汇编语言指令的基本格式是什么
汇编指令详解
MOV(MOVe) 传送指令PUSH 入栈指令POP 出栈指令XCHG(eXCHanG) 交换指令XLAT(TRANSLATE) 换码指令LEA (Load Effective Address) 有效地址送寄存器指令LDS(Load DS with pointer) 指针送寄存器和DS指令LES(Load ES with pointer) 指针送寄存器和ES指令LAHF(Load AH with Flags) 标志位送AH指令SAHF(Store AH into Flgs) AH送标志寄存器指令ADD 加法指令ADC 带进位加法指令INC 加1指令SUB(SUBtract) 不带借位的减法指令SBB(SuVtrach with borrow) 带借位的减法指令DEC(DECrement) 减1指领NEG(NEGate) 求补指令CMP(CoMPare) 比较指令MUL(unsinged MULtiple) 无符号数乘法指令IMUL(sIgned MUL tiple) 有符号数乘法指令DIV(unsigned DIVide) 无符号数除法指令IDIV(sIgned DIVide) 有符号数除法指令DAA 压缩的BCD码加法十进制调整指令DAS 压缩的BCD码减法十进制调整指令AAA 非压缩的BCD码加法十进制调整指令AAS 非压缩的BCD码加法十进制调整指令AND 逻辑与指令OR 逻辑或指令XOR 逻辑异或指令NOT 逻辑非指令TEST 测试指令SHL(SHift logical Letf) 逻辑左移指令SHR(SHift logical Right) 逻辑右移指令ROL(Rotate Left ) 循环左移指令ROR(Rotate Right) 循环右移指令RCL(Rotate Left through Carry) 带进位循环左移RCR(Rotate Right through Carry) 带进位循环左移MOVS(MOVe String) 串传送指令REP(REPeat) 重复操作前缀CLD(CLear Direction flag) 清除方向标志指令STD(SeT Direction flag) 设置方向标志指令CMPS(CoMPare String) 串比较指令SCAS(SCAn String) 串扫描指令REPE/REPZ(REPeat while Equal/Zero)相等/为零时重复操作前缀REPNE/REPNZ(REPeat while Not Equal/Zero)不相等/不为零进重复前缀JMP(JuMP) 无条件转移指令JZ,JNZ,JS,JNS,JO,JNO,JP,JNP,JB,JNB,JBE,JNBE,JL,JNL,JLE,JNLE,JCXZ 条件转移指令LOOP 循环指令P70LOOPZ/LOOPE 为零/相等时循环指令LOOPNZ/LOOPNE 不为零/不相等时循环指令CALL 子程序调用指令RET(RETun) 子程序返回指令NOP(No OPeretion) 无操作指令HLT(HaLT) 停机指令OFFSET 返回偏移地址SEG 返回段地址EQU(=) 等值语句DUP 操作数字段用复制操作符SEGMENT,ENDS 段定义指令ASSUME 段地址分配指令ORG 起始偏移地址设置指令$ 地址计数器的当前值PROC,ENDP 过程定义语句NAME,TITLE,END 程序开始结束语句MACRO,ENDM 宏定义指令
汇编语言中的cld是什么指令
cld指令功能:
将标志寄存器flag的方向标志位df清零。在字串操作中使变址寄存器si或di的地址指针自动增加,字串处理由前往后。例如,以下三条指令执行后,si自动加1,更新为0001h:
cld,mov si,0000hlodsb ;将字串中的si指针所指的一个字节装入al;
扩展资料:
汇编语言作为第二代计算机语言,用一些容易理解和记忆的字母,单词来代替一个特定的指令,比如:用“ADD”代表数字逻辑上的加减,“ MOV”代表数据传递等等,通过这种方法,人们很容易去阅读已经完成的程序或者理解程序正在执行的功能,对现有程序的bug修复以及运营维护都变得更加简单方便。
但计算机的硬件不认识字母符号,这时候就需要一个专门的程序把这些字符变成计算机能够识别的二进制数。因为汇编语言只是将机器语言做了简单编译,所以并没有根本上解决机器语言的特定性,所以汇编语言和机器自身的编程环境息息相关,推广和移植很难,但是还是保持了机器语言优秀的执行效率,因为他的可阅读性和简便性,汇编语言到现在依然是常用的编程语言之一。
汇编语言不像其他大多数的程序设计语言一样被广泛用于程序设计。在今天的实际应用中,它通常被应用在底层,硬件操作和高要求的程序优化的场合。驱动程序、嵌入式操作系统和实时运行程序都需要汇编语言。
主要的汇编指令有哪些啊
LDR 和STR——用于字和无符号字节指令格式:LDR/STR{cond}{T} Rd,《地址》LDR/STR{cond}B{T} Rd,《地址》 LDR{cond}{T} Rd,《地址》 加载指定地址的字数据到Rd中;STR{cond}{T} Rd,《地址》 存储Rd中的字数据到指定的地址单元中;LDR{cond}B{T} Rd,《地址》 指令加载指定地址的字节数据到Rd的的最低字节中(Rd的高24位清零);STR{cond}B{T} Rd, 《地址》 指令存储Rd中的最低字节数据到指定的地址单元中。 T为可选后缀,若有T,那么即使处理器是在特权模式下,存储系统也将访问看成处理器是在用户模式下,T 在用户模式下无效,不能与前索引偏移一起使用T。地址部分可用的形式有4种: 零偏移(zero offset) ;GPF4 output 0ldr r0,=0x2fffffbl delay ;调用延迟子程序b looptestdelaysub r0,r0,#1 ;r0=r0-1 cmp r0,#0x0 ;将r0的值与0相比较bne delay ;比较的结果不为0(r0不为0),继续调用delay,否则执行下一条语句mov pc,lr ;返回END ;程序结束符
汇编语言的几个简单指令,并附上中文解释
常用汇编指令: MOV 指令为双操作数指令,两个操作数中必须有一个是寄存器. MOV DST , SRC // Byte / Word 执行操作: dst = src 1.目的数可以是通用寄存器, 存储单元和段寄存器(但不允许用CS段寄存器). 2.立即数不能直接送段寄存器 3.不允许在两个存储单元直接传送数据 4.不允许在两个段寄存器间直接传送信息 PUSH 入栈指令及POP出栈指令: 堆栈操作是以“后进先出“的方式进行数据操作. PUSH SRC //Word 入栈的操作数除不允许用立即数外,可以为通用寄存器,段寄存器(全部)和存储器. 入栈时高位字节先入栈,低位字节后入栈. POP DST //Word 出栈操作数除不允许用立即数和CS段寄存器外, 可以为通用寄存器,段寄存器和存储器. 执行POP SS指令后,堆栈区在存储区的位置要改变. 执行POP SP 指令后,栈顶的位置要改变. XCHG(eXCHanG)交换指令: 将两操作数值交换. XCHG OPR1, OPR2 //Byte/Word 执行操作: Tmp=OPR1 OPR1=OPR2 OPR2=Tmp 1.必须有一个操作数是在寄存器中 2.不能与段寄存器交换数据 3.存储器与存储器之间不能交换数据. XLAT(TRANSLATE)换码指令: 把一种代码转换为另一种代码. XLAT (OPR 可选) //Byte 执行操作: AL=(BX+AL) 指令执行时只使用预先已存入BX中的表格首地址,执行后,AL中内容则是所要转换的代码. LEA(Load Effective Address) 有效地址传送寄存器指令 LEA REG , SRC //指令把源操作数SRC的有效地址送到指定的寄存器中. 执行操作: REG = EAsrc 注: SRC只能是各种寻址方式的存储器操作数,REG只能是16位寄存器 MOV BX , OFFSET OPER_ONE 等价于 LEA BX , OPER_ONE MOV SP , //将BX的内容作为存储器有效地址送入SP中 LDS(Load DS with pointer)指针送寄存器和DS指令 LDS REG , SRC //常指定SI寄存器。 执行操作: REG=(SRC), DS=(SRC+2) //将SRC指出的前二个存储单元的内容送入指令中指定的寄存器中,后二个存储单元送入DS段寄存器中。
汇编语言中JB,JA,是什么意思
汇编语言中JB、JA都是条件转移指令,常用于比较两个无符号数的大小,判断条件是CF、ZF状态的组合。为确定CF、ZF状态,转移前用CMP指令设置标志位(CMPA,B)。其中:指令JA表示CF=0且ZF=0即A》B转移。指令JB表示CF=1且ZF=0即A《B转移。许多汇编程序为程序开发、汇编控制、辅助调试提供了额外的支持机制。有的汇编语言编程工具经常会提供宏,它们也被称为宏汇编器。汇编语言不像其他大多数的程序设计语言一样被广泛用于程序设计。在今天的实际应用中,它通常被应用在底层,硬件操作和高要求的程序优化的场合。驱动程序、嵌入式操作系统和实时运行程序都需要汇编语言。扩展资料语言特点汇编语言是直接面向处理器(Processor)的程序设计语言。处理器是在指令的控制下工作的,处理器可以识别的每一条指令称为机器指令。每一种处理器都有自己可以识别的一整套指令,称为指令集。处理器执行指令时,根据不同的指令采取不同的动作,完成不同的功能,既可以改变自己内部的工作状态,也能控制其它外围电路的工作状态。汇编语言的另一个特点就是它所操作的对象不是具体的数据,而是寄存器或者存储器,也就是说它是直接和寄存器和存储器打交道,但同时这也使编程更加复杂,因为既然数据是存放在寄存器或存储器中,那么必然就存在着寻址方式,也就是用什么方法找到所需要的数据。这也就增加了编程的复杂性,因为在高级语言中寻址这部分工作是由编译系统来完成的,而在汇编语言中是由程序员自己来完成的,这无异增加了编程的复杂程度,降低了程序的可读性。参考资料来源:百度百科-汇编语言
汇编语言常用指令
单片机汇编语言汇编错误原因分析汇编语言的指令格式,目前有两种不同的标准:Windows下的汇编语言基本上都遵循Intel风格的语法,比如:MASM、NASM;而Unix/Linux下的汇编语言基本上都遵循AT&T风格的语法;一、汇编语言语句的通用格式 指令码 源操作数SRC,目的操作数DST ;注释例如: CYCLE: ADD AX,02H ;(AX)汇编语言语句格式中的“名称“并不是所有语句都必需的,但是,如果语句中带有“名称“,那么,大多数情况下,“名称“都表示的是内存中某一存储单元的地址,也就是“名称“后面各项在内存中存放的第一个存储单元的地址(包括该“名称“所在段的段地址和段内偏移地址);比如上面的指令中,CYCLE就是该语句的名称,CYCLE表示的就是其后面的机器指令码在内存中存放的第一个地址;“名称“与指令码之间的分隔符可以是冒号“:“,也可以是空格字符“ “;当以冒号分割时,该名称代表的是一个标号;当以空格分割时,该名称代表的可能是标号,也可能是变量;当指令码有多个操作数的时候,相邻两个操作数之间要用逗号“,“分割;指令码与操作数之间必须以空格分割;汇编语言语句的注释必须以分号“;“开头;二、组成语句的元素1、常数:汇编语言中的常数有整数、字符串;二进制、八进制、十进制、十六进制;汇编语言采用不同的后缀区分:B:二进制数; O:八进制数; D:十进制数; H:十六进制数;当一个数值后面没有后缀的时候,默认为十进制数;字符串常数是用一对单引号(’’)括起来的一串字符;2、表达式:由操作数和操作符组成;算数运算操作符: +、-、*、/、MOD,等;取模运算MOD是取两数相除的余数;逻辑运算操作符: AND(逻辑与)、OR(逻辑或)、NOT(逻辑非)、XOR(逻辑异或);注意:逻辑运算符同时又可以是逻辑运算指令的指令码,只有当它们出现在指令的操作数部分时,才是操作符;例如:ADD AL,0CH ADD 0FH ;第一个ADD是指令码,第二个ADD是操作符;关系运算操作符: EQ(相等)、NE(不等)、LT(小于)、GT(大于)、LE(小于等于)、GE(大于等于);汇编语言中的表达式不能单独构成语句,只能是语句的组成部分;注意:语句中表达式的求值不是在语句执行时完成的,而是在对源程序进行汇编链接时完成的.所以,语句中各表达式的值必须在汇编或链接时就是确定的,也就是说,表达式中各标识符的值在汇编或链接时就应该是确定的;3、标号:标号是由标识符表示的指令的名称,用于指示对应指令的位置(地址);标号具有三个属性:段地址、偏移地址和类型;标号的段地址和偏移地址属性是指该标号所对应的指令所在段的段地址和段内偏移地址;标号的类型有两种:NEAR和FAR;标号定义成NEAR类型,表示该标号在段内使用,而定义成FAR类型则表示该标号可以在段间使用;标号的定义:在指令码前面加上标识符和冒号“:“;例如:START: PUSH DS这条语句里面,START就是我们定义的标号,它代表指令PUSH的地址,所以,标号可以作为程序转移指令的操作数(即:要转向的地址);标号还可以采用伪指令来定义;例如:用LABEL伪指令和过程定义伪指令来定义;4、变量:与高级语言一样,并不是所有的操作数都是常数,汇编语言也有自己的变量,变量的值在程序运行期间是可以被改变的;A.定义变量:汇编语言中,变量的定义是通过伪指令来完成的;定义变量的伪指令格式如下:变量名 DB 表达式 ;定义字节变量,又称单字节变量(1个连续字节),DB--》BYTE变量名 DW 表达式 ;定义字变量,又称双字节变量(2个连续字节),DW--》WORD变量名 DD 表达式 ;定义双字变量,又称四字节变量(4个连续字节),DD--》DWORD变量名 DF 表达式 ;定义六字节变量,又称六字节变量(6个连续字节),DF--》FWORD变量名 DQ 表达式 ;定义长字变量,又称八字节变量(8个连续字节),DQ--》QWORD变量名 DT 表达式 ;定义十字节变量(10个连续字节),DT--》TBYTE;其中,变量名是一个合法的标识符,变量名后面不能加冒号“:“,只能用空格;变量名不是必要的,可有可无;变量的类型由关键字DB、DW、DD、DQ、DT来定义;变量定义语句中的“表达式“是用于对变量进行初始化的,可有一下几种情况:(1).一个或多个常数或表达式;当为多个常数或表达式时,期间要用逗号隔开;如DATA1--DATA4;(2).带单引号的字符串;对于字节型(DB)变量,每个变量的大小为1个字节,每个变量的值不能超过1个字符,每个字节内存入一个字符的ASCII码值,整个字符串可以在同一对单引号内给出,这相当于是定义了一个字符数组,如DATA5;对于字类型(DW)变量,每个变量的大小为2个字节,每个变量的值不能超过2个字符,若为2个字符时,同样遵循高位存入高字节,低位存入低字节的规则;若为1个字符,则该字符的ASCII码值存入到低字节,高字节为00,如DATA6;对于双字类型(DD)变量,每个变量的大小为4个字节,每个变量的值不能超过2个字符,若为2个字符,同样遵循高位存入高字节,低位存入低字节的规则;但是2个字符的值被存入到双字变量的最低2个字节中,1个字符的值被存入到双字变量的最低1个字节中;对于长字类型(DQ)变量,每个变量的大小为8个字节,每个变量的值不能超过2个字符,若为2个字符,同样遵循高位存入高字节,低位存入低字节的规则;但是2个字符的值被存入到长字变量的最低2个字节中,1个字符的值被存入到长字变量的最低1个字节中;(3).一个问号“?“,表示该变量的值不确定,即:该变量所表示的内存单元中的内容是不确定的,或者说是,当表达式为问号时,变量所对应的内存区中并没有存入新的值,而只是预留出了相应的存储空间;如DATA7、DATA8(4).重复方式;此时的格式为: 重复次数 DUP(表达式);重复方式指出表达式的值可以重复地存储到变量对应的内存区中,重复的次数由伪指令给出,相当于定义数组;如DATA9、DATA10定义变量的例子:DATA1 DB 20H ;1字节变量DATA2 DW 0204H,1000H ;2字节变量DATA3 DB (-1*3),(15/3) ;1字节变量DATA4 DD 123456H ;4字节变量DATA5 DB ’0123’ ;字符串变量,相当于一个字符数组DATA6 DW ’AB’,’C’,’D’ ;字符串变量,相当于一个字符串数组;DATA7 DB ? ;1字节变量,未初始化DATA8 DD ? ;4字节变量,未初始化DATA9 DB 5 DUP(0) ;1字节变量,用5个0初始化,相当于是一个具有5个DB型元素的数组DATA10 DW 3 DUP(?) ;2字节变量,未初始化,相当于是一个具有3个DW型元素的数组变量定义语句中伪指令的功能是在变量名所对应的地址开始的内存区依次存入表达式中的各项值,表达式中的每项值所占用内存字节数与变量的类型对应;总结:一个变量的变量名实际上就代表了该变量所对应的内存区在内存段中的有效地址(偏移地址);高地址是指地址值相对较大,低地址是指地址值相对较小,高地址与低地址是相对而言的;5、变量的属性:(1).属性介绍一个变量具有一下属性:A.段地址(SEG):变量所在段的段地址;B.偏移地址(OFFSET):变量所在段内的偏移地址;C.类型(TYPE):变量的类型定义了每个变量所占用的内存字节数,对于DB、DW、DD、DQ、DT类型定义的变量所占用的内存字节数分别是1、2、4、8、10;通常又将DB、DW、DD类型所定义的变量分别成为BYTE类型、WORD类型、DWORD类型变量;常用标识符的类型值列表:标识符种类 字节变量 字变量 双字变量 近标号NEAR 远标号FARTYPE的值 1 2 4 -1 -2D.长度(LENGTH):变量定义时,一个变量名所定义的变量个数;在含有DUP操作符的变量定义中,变量名所定义的变量个数为定义格式中的重复次数;在其它各种变量定义中,每个变量名所定义的变量个数均为1个;E.大小(SIZE):变量定义语句中,分配给同一个变量名的所有变量的总的字节数,其值为该变量的类型与长度的成绩;其中,段地址、偏移地址和类型属性是变量的主属性,而长度和大小属性是变量的辅助属性;(2).属性操作符:操作符 表达式 含义SEG SEG 变量名或标号 取出变量名或标号所在段的段地址OFFSET OFFSET 变量名或标号 取出变量名或标号所在段内的偏移地址TYPE TYPE 变量名或标号 取出变量名或标号的类型(变量所占用的字节数)LENGTH LENGTH 变量名 取出变量的长度SIZE SIZE 变量名 取出变量的大小这些操作符不能单独构成语句,只能作为表达式的组成部分,并且表达式的求值也是在汇编过程中完成的;6.强制类型转换操作符PTR格式:数据类型 PTR 地址表达式格式中的“数据类型“可以是BYTE、WORD、DWORD、NEAR、FAR;前三种类型是变量的类型,后两种类型是标号的类型;格式中的表达式可以是变量、标号、其它地址表达式;PTR操作符的功能是用来重新定义已定义的变量或标号的类型,其作用域只在当前语句中; 例如:DATA1 DW 02HMOV BYTE PTR DATA1,AL这条指令中,是把DATA1的类型转换为BYTE类型,然后把AL中的内容存放到DATA1的最低一个字节中;作用域只在这条MOV语句中,过了这条语句,DATA1仍然是DW类型,即:DATA1原来的类型并没有被修改;
汇编语言中的jb是什么意思
汇编语言中JB、JA都是条件转移指令,常用于比较两个无符号数的大小,判断条件是CF、ZF状态的组合。为确定CF、ZF状态,转移前用CMP指令设置标志位(CMPA,B)。其中:指令JA表示CF=0且ZF=0即A》B转移。指令JB表示CF=1且ZF=0即A《B转移。许多汇编程序为程序开发、汇编控制、辅助调试提供了额外的支持机制。有的汇编语言编程工具经常会提供宏,它们也被称为宏汇编器。扩展资料汇编语言能够利用计算机的所有硬件特性并能够直接控制硬件的唯-语言。但是由于编写和调试汇编语言程序要比高级语言复杂,因此目前其应用不如高级语言广泛。汇编语言比机器语言的可读性要好,但跟高级语言比较而言,可读性还是较差。不过采用它编写的程序具有存储空间占用少、执行速度快的特点,这些是高级语言所无法取代的。在实际应用中,是否使用汇编语言,取决于具体应用要求、软件开发时间和质量等方面作权衡。汇编语言的优点1)可以轻松的读取存储器状态以及硬件I/O接口情况2)编写的代码因为少了很多编译的环节,可以能够准备的被执行3)作为一种低级语言,可扩展性很高汇编语言的缺点1)因为代码非常单调,特殊指令字符很少,所以造成了代码的冗长以及编写的困难2)因为汇编仍然需要自己去调用存储器存储数据,很容易出现BUG,而且调试起来也不容易3)就算完成了一个程序,后期维护时候也需要耗费大量的时间。4)因为机器的特殊性造成了代码兼容性差的缺陷。参考资料来源:百度百科-汇编语言
汇编语言org指令怎么用
ORG是Origin的缩写:起始地址,源。在汇编语言源程序的开始通常都用一条ORG伪指令来实现规定程序的起始地址。如果不用ORG规定则汇编得到的目标程序将从0000H开始。
ORG的使用:
ORG2000H
START:MOVAX,#00H
扩展资料
51单片机最常用的伪指令如下:
(1)起始(Origin)伪指令
标号:ORGnn
功能:定义程序或数据块的起始地址。指示此语句后面的程序或数据块以nn为起始地址连续存放在程序存储器中。
例如:
ORG2000H
MOVA,20H
…
ORG伪指令规定了程序的起始地址从2000H开始,即该程序的第一条指令“MOVA,20H”从地址2000H开始存放。)
(2)字节定义(DefineByte)伪指令
标号:DB(字节常数或字符或表达式)
功能:指示在程序存储器中以标号为起始地址的单元里存放的数为字节数据(8位二进制数)。
例如:
OGR100H
TAB1:DB0FFH,’C’,16,−1
从TAB1开始的地址单元依次存放0FFH、43H、10H、0FFH
汇编语言中CMP是什么意思
cmp是比较指令, cmp的功能相当于减法指令,只是不保存结果。cmp指令执行后,将对标志寄存器产生影响。其他相关指令通过识别这些被影响的标志寄存器位来得知比较结果。
比如:
mov ax,8
mov bx,3
cmp ax,bx
执行后:ax=8,ZF=0,PF=1,SF=0,CF=0,OF=0.
通过cmp指令执行后,相关标志位的值就可以看出比较的结果。
cmp ax,bx的逻辑含义是比较ax,bx中的值。如果执行后:
ZF=1则AX=BX
ZF=0则AX!=BX
SF=1则AX《BX
SF=0则AX》=BX
SF=0并ZF=0则AX》BX
SF=1或ZF=1则AX《=BX
CPU在执行cmp指令的时候,也包含两种含义:进行无符号运算和进行有符号数运算。
cmp ah,bh
如果ah=bh则ah-bh=0所以ZF=1
如果ah≠bh则ah-bh≠0所以ZF=0
所以我们根据cmp指令执行后ZF的值,就可以知道两个数据是否相等。如果ah《bh则可能发生什么情况呢?
对于有符号数运算,在ah《bh情况下,ah-bh显然可能引起SF=1既结果为负比如:
ah=1,bh=2则ah-bh=0FFH,0FFH为-1的补码,因为结果为负,所以SF=1。
ah=0FEH,bx=OFFH;则ax-bx=-2-(-1)=OFFH,因为结果为负,所以SF=1。
扩展资料:
汇编语言的常用指令集如下:
数据传送指令集
MOV
功能: 把源操作数送给目的操作数
语法: MOV 目的操作数,源操作数
格式: MOV r1,r2
MOV r,m
MOV m,r
MOV r,data
XCHG
功能: 交换两个操作数的数据
语法: XCHG
格式: XCHG r1,r2 XCHG m,r XCHG r,m
PUSH,POP
功能: 把操作数压入或取出堆栈
语法: PUSH操作数POP 操作数
格式: PUSH r PUSH M PUSH data POP r POP m
PUSHF,POPF,PUSHA,POPA
功能:堆栈指令群
格式: PUSHF POPF PUSHA POPA
LEA,LDS,LES
功能: 取地址至寄存器
语法: LEA r,m LDS r,m LES r,m
XLAT(XLATB)
功能:查表指令
语法: XLAT XLAT m
算术运算指令
ADD,ADC
功能: 加法指令
语法: ADD OP1,OP2 ADC OP1,OP2
格式: ADD r1,r2 ADD r,m ADD m,r ADD r,data
影响标志: C,P,A,Z,S,O
SUB,SBB
功能:减法指令
语法: SUB OP1,OP2 SBB OP1,OP2
格式: SUB r1,r2 SUB r,m SUB m,r SUB r,data SUB m,data
影响标志: C,P,A,Z,S,O
INC,DEC
功能: 把OP的值加一或减一
语法: INC OP DEC OP
格式: INC r/m DEC r/m
影响标志: P,A,Z,S,O
NEG
功能: 将OP的符号反相(取二进制补码)
语法: NEG OP
格式: NEG r/m
影响标志: C,P,A,Z,S,O
MUL,IMUL
功能: 乘法指令
语法: MUL OP IMUL OP
格式: MUL r/m IMUL r/m
影响标志: C,P,A,Z,S,O(仅IMUL会影响S标志)
DIV,IDIV
功能:除法指令
语法: DIV OP IDIV OP
格式: DIV r/m IDIV r/m
CBW,CWD
功能:有符号数扩展指令
语法: CBW CWD
AAA,AAS,AAM,AAD
功能: 非压BCD码运算调整指令
语法: AAA AAS AAM AAD
影响标志: A,C(AAA,AAS) S,Z,P(AAM,AAD)
参考资料来源:百度百科-CMP指令
汇编语言指令的基本格式是什么
汇编语言中anl指令是一个逻辑“与”运算的指令有两层意思:1、对字节变量进行逻辑与。格式为:anl,比如:anla,r0anlp1,#01h2、对位变量进行逻辑与。格式为:anlc,比如:anlc,acc.0
更多文章:
showmodal(delphi中show和showmodal的区别)
2024年7月3日 09:31
如何写个人职业生涯主题内容?关于勇敢主题个人励志演讲稿优秀范文三篇
2024年7月3日 01:58
XDATA寻址空间为多少字节?51单片机定义一个大数组存在idata与xdata中有什么区别
2024年5月19日 03:14
广西网站建设(广西最厉害的网络公司,南宁最厉害的网站建设公司)
2024年7月24日 03:43
嵌入式linux系统中进行开发(linux嵌入式开发是不是必须用linux才能开发_linux嵌入式开发是什么)
2024年7月24日 14:47
matlab傅里叶变换的幅度谱和相位谱(在 MATLAB 下如何实现对一组数据振幅谱和相位谱)
2024年4月22日 06:50
粤绣为什么能成为中国四大名绣之一粤绣有什么特点?粤绣与其他绣有什么不同之处
2024年7月24日 11:13
企业标准模板(来份WORD格式GB/T1.1-2009企业标准要齐全点,谢谢了)
2024年7月11日 09:48
queue full什么意思(循环队列中rear、front 初始值是什么)
2024年7月24日 08:05