微机原理汇编常用指令
微机原理中部分指令列表汇总
条件转移指令指令助记符转移条件含义无符号数条件转移指令JA/JNBE CF=ZF=0 高于,转移/不低于或等于,转移JAE/JNB CF=0 高于或等于,转移/不低于,转移JB/JNAE CF=1 低于,转移/不高于或等于,转移JBE/JNA CF=1或ZF=1 低于或等于,转移/不高于,转移JE/JZ ZF=1 等于,转移/为零,转移JNE/JNZ ZF=0 不等于,转移/ 不为零,转移有符号数条件转移指令JE/JZ ZF=1 等于,转移/为零,转移JG/JNLE ZF=0或SF=OF 大于,转移/不小于或等于,转移JGE/JNL SF=OF 大于或等于,转移/不小于,转移JL/JNGE SF≠OF 小于,转移/不大于或等于,转移JLE/JNG ZF=1或SF≠OF 小于或等于,转移/不大于,转移JNE/JNZ ZF=0 不等于,转移/ 不为零,转移其他条件转移指令JB/JC CF=1 有借/进位,转移JNC CF=0 无进位,转移JNO OF=0 无溢出,转移JNP/JPO PF=0 无奇偶校验,转移/奇校验,转移JNS SF=0 无符号,转移JO OF1 溢出,转移JP/JPE PF=1 有奇偶校验,转移/偶校验,转移JS SF=1 有符号,转移JCXZ (CX)=0 CX寄存器为0,转移标志位操作指令指令名指令格式功能说明清进位指令CLC 清进位标志CF(CF←0)置进位指令STC 置进位标志(CF←1)进位取反指令CMC 进位标志取反(CF←/CF)清方向标志指令CLD 清方向标志(DF←0),使所有串指令的标识指针为增量置方向标志指令STD 置方向标志(DF←1),使所有串指令的标识指针为减量关中断指令CLI 清中断允许标志(IF←0),禁止CPU响应外部可屏蔽中断开中断指令STI 置中断允许标志(IF←1),允许CPU响应外部可屏蔽中断条件设置字节指令指令助记符设置条件指令条件说明SETC/SETB/SETNAE CF=1 有进位/低于/不高于或等于SETNC/SETAE/SETNB CF=0 无进位/高于或等于/不低于SETO OF=1 溢出SETNO OF=0 无溢出SETP/SETPE PF=1 校验为偶SETNP/SETPO PF=0 校验为奇SETS SF=1 为负数SETNS SF=0 为正数SETA/SETNBE CF=ZF=0 高于/不低于或等于SETBE/SETNA CF=1或ZF=1 低于或等于/不高于SETE/SETZ ZF=1 等于/为零SETNE/SETNZ ZF=0 不等于/非零SETG/SETNLE ZF=1或SF=OF 大于/不小于或等于SETGE/SETNL SF=OF 大于或等于/不小于SETL/SETNGE SF≠OF 小于/不大于或等于SETLE/SETNG ZF=1或SF≠OF 小于或等于/不大于系统寄存器装入与存储指令指令名指令格式功能装入CR指令MOV CR n,32位通用寄存器CR n←(32位通用寄存器),n=0,2,3,4存储CR指令MOV 32位通用寄存器,CR n32位通用寄存器←(CRn),n=0,2,3,4装入DR指令MOV DR n,32位通用寄存器DR n←(32位通用寄存器),n=0~7存储DR指令MOV 32位通用寄存器,DR n32位通用寄存器←(DR n),n=0~7读模型专用寄存器RDMSR EDX:EAX←(MSR), ECX指定寄存器号00H~13H 写模型专用寄存器WRMSR MSR←(EDX:EAX), ECX指定寄存器号00H~13H 装入机器状态字LMSW 源操作数MSW←(源操作数)存储机器状态字SMSW 目的操作数目的操作数←(MSW)装入GDTR/IDTR LGDT/LIDT 存储器GDTR/IDTR←(存储器)存储GDTR/IDTR SGDT/SIDT 存储器存储器←(GDTR)/(IDTR)装入LDTR LLDT 源操作数LDTR←(源操作数)存储LDTR SLDT 目的操作数目的操作数←(LDTR)装入任务寄存器LTR 源操作数TR←(源操作数)存储任务寄存器STR 目的操作数目的操作数←(TR)外同步和空操作指令类别指令格式功能外同步HLT 使CPU停止程序执行,进入暂停状态。
微机原理常用命令
一、数据传输指令它们在存贮器和寄存器、寄存器和输入输出端口之间传送数据。
1. 通用数据传送指令MOV 传送字或字节.MOVSX 先符号扩展,再传送.MOVZX 先零扩展,再传送.PUSH 把字压入堆栈.POP 把字弹出堆栈.PUSHA 把AX,CX,DX,BX,SP,BP,SI,DI依次压入堆栈.POPA 把DI,SI,BP,SP,BX,DX,CX,AX依次弹出堆栈.PUSHAD 把EAX,ECX,EDX,EBX,ESP,EBP,ESI,EDI依次压入堆栈.POPAD 把EDI,ESI,EBP,ESP,EBX,EDX,ECX,EAX依次弹出堆栈.BSWAP 交换32位寄存器里字节的顺序XCHG 交换字或字节.( 至少有一个操作数为寄存器,段寄存器不可作为操作数) CMPXCHG 比较并交换操作数.( 第二个操作数必须为累加器AL/AX/EAX ) XADD 先交换再累加.( 结果在第一个操作数里)XLAT 字节查表转换.── BX 指向一张256 字节的表的起点, AL 为表的索引值(0-255,即0-FFH); 返回AL 为查表结果. ( [BX+AL]->AL )2. 输入输出端口传送指令.IN I/O端口输入. ( 语法: IN 累加器, {端口号│DX} )OUT I/O端口输出. ( 语法: OUT {端口号│DX},累加器)输入输出端口由立即方式指定时, 其范围是0-255; 由寄存器DX 指定时,其范围是0-65535.3. 目的地址传送指令.LEA 装入有效地址.例: LEA DX,string ;把偏移地址存到DX.LDS 传送目标指针,把指针内容装入DS.例: LDS SI,string ;把段地址:偏移地址存到DS:SI.LES 传送目标指针,把指针内容装入ES.例: LES DI,string ;把段地址:偏移地址存到ES:DI.LFS 传送目标指针,把指针内容装入FS.例: LFS DI,string ;把段地址:偏移地址存到FS:DI.LGS 传送目标指针,把指针内容装入GS.例: LGS DI,string ;把段地址:偏移地址存到GS:DI.LSS 传送目标指针,把指针内容装入SS.例: LSS DI,string ;把段地址:偏移地址存到SS:DI.4. 标志传送指令.LAHF 标志寄存器传送,把标志装入AH.SAHF 标志寄存器传送,把AH内容装入标志寄存器.PUSHF 标志入栈.POPF 标志出栈.PUSHD 32位标志入栈.POPD 32位标志出栈.二、算术运算指令ADD 加法.ADC 带进位加法.INC 加1.AAA 加法的ASCII码调整.DAA 加法的十进制调整.SUB 减法.SBB 带借位减法.DEC 减1.NEC 求反(以0 减之).CMP 比较.(两操作数作减法,仅修改标志位,不回送结果).AAS 减法的ASCII码调整.DAS 减法的十进制调整.MUL 无符号乘法.IMUL 整数乘法.以上两条,结果回送AH和AL(字节运算),或DX和AX(字运算), AAM 乘法的ASCII码调整.DIV 无符号除法.IDIV 整数除法.以上两条,结果回送:商回送AL,余数回送AH, (字节运算);或商回送AX,余数回送DX, (字运算).AAD 除法的ASCII码调整.CBW 字节转换为字. (把AL中字节的符号扩展到AH中去)CWD 字转换为双字. (把AX中的字的符号扩展到DX中去)CWDE 字转换为双字. (把AX中的字符号扩展到EAX中去) CDQ 双字扩展. (把EAX中的字的符号扩展到EDX中去) 三、逻辑运算指令AND 与运算.or 或运算.XOR 异或运算.NOT 取反.TEST 测试.(两操作数作与运算,仅修改标志位,不回送结果).SHL 逻辑左移.SAL 算术左移.(=SHL)SHR 逻辑右移.SAR 算术右移.(=SHR)ROL 循环左移.ROR 循环右移.RCL 通过进位的循环左移.RCR 通过进位的循环右移.以上八种移位指令,其移位次数可达255次.移位一次时, 可直接用操作码. 如SHL AX,1.移位>1次时, 则由寄存器CL给出移位次数.如MOV CL,04SHL AX,CL四、串指令DS:SI 源串段寄存器:源串变址.ES:DI 目标串段寄存器:目标串变址.CX 重复次数计数器.AL/AX 扫描值.D标志0表示重复操作中SI和DI应自动增量; 1表示应自动减量.Z标志用来控制扫描或比较操作的结束.MOVS 串传送.( MOVSB 传送字符. MOVSW 传送字. MOVSD 传送双字. )CMPS 串比较.( CMPSB 比较字符. CMPSW 比较字. )SCAS 串扫描.把AL或AX的内容与目标串作比较,比较结果反映在标志位.LODS 装入串.把源串中的元素(字或字节)逐一装入AL或AX中.( LODSB 传送字符. LODSW 传送字. LODSD 传送双字. )STOS 保存串.是LODS的逆过程.REP 当CX/ECX<>0时重复.REPE/REPZ 当ZF=1或比较结果相等,且CX/ECX<>0时重复.REPNE/REPNZ 当ZF=0或比较结果不相等,且CX/ECX<>0时重复.REPC 当CF=1且CX/ECX<>0时重复.REPNC 当CF=0且CX/ECX<>0时重复.五、程序转移指令1>无条件转移指令(长转移)JMP 无条件转移指令CALL 过程调用RET/RETF过程返回.2>条件转移指令(短转移,-128到+127的距离内)( 当且仅当(SF XOR OF)=1时,OP1<OP2 )JA/JNBE 不小于或不等于时转移.JAE/JNB 大于或等于转移.JB/JNAE 小于转移.JBE/JNA 小于或等于转移.以上四条,测试无符号整数运算的结果(标志C和Z).JG/JNLE 大于转移.JGE/JNL 大于或等于转移.JL/JNGE 小于转移.JLE/JNG 小于或等于转移.以上四条,测试带符号整数运算的结果(标志S,O和Z).JE/JZ 等于转移.JNE/JNZ 不等于时转移.JC 有进位时转移.JNC 无进位时转移.JNO 不溢出时转移.JNP/JPO 奇偶性为奇数时转移.JNS 符号位为"0" 时转移.JO 溢出转移.JP/JPE 奇偶性为偶数时转移.JS 符号位为"1" 时转移.3>循环控制指令(短转移)LOOP CX不为零时循环.LOOPE/LOOPZ CX不为零且标志Z=1时循环.LOOPNE/LOOPNZ CX不为零且标志Z=0时循环.JCXZ CX为零时转移.JECXZ ECX为零时转移.4>中断指令INT 中断指令INTO 溢出中断IRET 中断返回5>处理器控制指令HLT 处理器暂停, 直到出现中断或复位信号才继续.WAIT 当芯片引线TEST为高电平时使CPU进入等待状态.ESC 转换到外处理器.LOCK 封锁总线.NOP 空操作.STC 置进位标志位.CLC 清进位标志位.CMC 进位标志取反.STD 置方向标志位.CLD 清方向标志位.STI 置中断允许位.CLI 清中断允许位.六、伪指令DW 定义字(2字节).PROC 定义过程.ENDP 过程结束.SEGMENT 定义段.ASSUME 建立段寄存器寻址.ENDS 段结束.END 程序结束.七、处理机控制指令:标志处理指令CLC(进位位置0指令)CMC(进位位求反指令)STC(进位位置为1指令)CLD(方向标志置1指令)STD(方向标志位置1指令)CLI(中断标志置0指令)STI(中断标志置1指令)NOP(无操作)HLT(停机)WAIT(等待)ESC(换码)LOCK(封锁)。
微机原理 指令大全
MOV(MOVe)传送指令P86PUSH入栈指令P86POP出栈指令P87XCHG(eXCHanG)交换指令P88XLAT(TRANSLATE)换码指令P89LEA (Load Effective Address)有效地址送寄存器指令P89 LDS(Load DS with pointer)指针送寄存器和DS指令P90 LES(Load ES with pointer)指针送寄存器和ES指令P90 LAHF(Load AH with Flags)标志位送AH指令P91SAHF(Store AH into Flgs) AH送标志寄存器指令P91 PUSHF(PUSH the Flags)标志进栈指令P91POPF(POP the Flags)标志出栈指令P91ADD加法指令P92ADC带进位加法指令P92INC加1指令P92SUB(SUBtract)不带借位的减法指令P93SBB(SuVtrach with borrow)带借位的减法指令P93DEC(DECrement)减1指领P93NEG(NEGate)求补指令P93CMP(CoMPare)比较指令P93MUL(unsinged MULtiple)无符号数乘法指令P93IMUL(sIgned MUL tiple)有符号数乘法指令P93DIV(unsigned DIVide)无符号数除法指令P94IDIV(sIgned DIVide)有符号数除法指令P94CBW(Count Byte to Word)字节转换为字指令P94CWD(Count Word to Doble word)字转换为双字指令P94 DAA压缩的BCD码加法十进制调整指令P95DAS压缩的BCD码减法十进制调整指令P95AAA非压缩的BCD码加法十进制调整指令P95AAS非压缩的BCD码加法十进制调整指令P95 AAM,AAD AND逻辑与指令P96OR逻辑或指令P96XOR逻辑异或指令P96NOT逻辑非指令P96TEST测试指令P96SHL(SHift logical Letf)逻辑左移指令P97SHR(SHift logical Right)逻辑右移指令P97SALSARROL(Rotate Left )循环左移指令P98ROR(Rotate Right)循环右移指令P98RCL(Rotate Left through Carry)带进位循环左移P98 RCR(Rotate Right through Carry)带进位循环左移P98 MOVS(MOVe String)串传送指令P100STOS(STOre into String)存入串指令P102LODS(LOad from string)从串取指令P102REP(REPeat)重复操作前缀P99CLD(CLear Direction flag)清除方向标志指令107STD(SeT Direction flag)设置方向标志指令107CMPS(CoMPare String)串比较指令100SCAS(SCAn String)串扫描指令101REPE/REPZ(REPeat while Equal/Zero)相等/为零时重复操作前缀99REPNE/REPNZ(REPeat while Not Equal/Zero)不相等/不为零进重复前缀99IN(INput)输入指令88OUT(OUTput)输出指令88JMP(JuMP)无条件转移指令103JZ,JNZ,JS,JNS,JO,JNO,JP,JNP,JB,JNB,JBE,JNBE,JL,JNL,JLE,JNLE,JCXZ条件转移指令103LOOP循环指令105LOOPZ/LOOPE为零/相等时循环指令105LOOPNZ/LOOPNE不为零/不相等时循环指令105CALL子程序调用指令106RET(RETun)子程序返回指令106CLC(CLear Carry)进位位置0指令107CMC(CoMplement Carry)进位位求反指令107SRC(SeT Carry)进位位置1指令NOP(No OPeretion)无操作指令 107HLT(HaLT)停机指令107OFFSET返回偏移地址 141SEG返回段地址141 TYPE SIZE LENGTH 142EQU(=)等值语句128PURGE解除语句128DUP操作数字段用复制操作符127SEGMENT,ENDS段定义指令129ASSUME段地址分配指令130ORG起始偏移地址设置指令132$地址计数器的当前值PROC,ENDP过程定义语句131NAME,TITLE,END程序开始结束语句131,132MACRO,ENDM宏定义指令147STRUC,ENDS 133PUBLIC,EXTRN 136EVEN 138MOD 139IF, END IF 138EQ, NE,LT,GT,LE,GE 140THIS SHORT HIGH LOW 144INT 20H INT 21H 153Welcome 欢迎您的下载,资料仅供参考!。
微机原理汇编指令1
数值型表达式
数值表达式一般是指由运算符连接的各种常数所构成的表 达式。 汇编程序在汇编过程中计算表达式,最终得到一个数值。
目 录
前一页
后一页
退出
运算符
算术运算符 + - * / MOD 逻辑运算符 AND OR XOR NOT 移位运算符 SHL SHR 关系运算符 EQ NE GT LT GE LE 高低分离符 HIGH LOW HIGHWORD LOWWORD 目 前一页 后一页 录
退出
算术运算符
实现加、减、乘、除、取余的算术运算 mov ax , 3 * 4 + 5 ;等价于 mov ax,17 其中MOD也称为取模,它产生除法之后的余数,如 19 mod 7 = 5 加+和减-运算符还可以用于地址表达式。 两个地址相乘、相除是无意义的; 两个不同段的地址相加也是无意义的。 经常使用的是地址±数字量,它是有意义的。 除加、减外,其他运算符的参数必须是整数。
目 录
前一页
后一页
退出
例4.27
地址操作符
MOV BX , OFFSET OPER_ONE ;与LEA BX , OPER_ONE等价 例4.28 如果DATA_SEG是从存储器05000H地址开始 的一个数据段的段名,OPER1是该段中的一个变量名。 MOV BX , SEG OPER1 ;汇编结果:MOV BX , 0500H ;将OPER1所在段的起始偏移地址送入BX。
目 录
前一页
后一页
退出
例:
THIS操作符举例 b_var equ THIS byte ;按字节访问变量b_var,但与w_var的地址相同 w_var dw 10 dup(0) ;按字访问变量w_var
汇编的基本常用指令
汇编的基本常用指令汇编语言是一种底层的计算机语言,用于编写程序和指令集。
在汇编语言中,指令是一种特定的操作码,它告诉计算机执行某种操作。
在这篇文章中,我们将介绍汇编语言中一些基本常用的指令。
一、数据传输指令数据传输指令用于在寄存器和内存之间传输数据。
下面是一些常用的数据传输指令:1. MOVMOV指令用于将数据从一个位置复制到另一个位置。
例如,MOV AX, BX将寄存器BX中的数据复制到AX寄存器中。
2. XCHGXCHG指令用于交换两个位置的数据。
例如,XCHG AX, BX将AX和BX寄存器中的数据互换。
3. PUSHPUSH指令用于将数据压入栈。
例如,PUSH AX将AX寄存器的值压入栈中。
4. POPPOP指令用于从栈中弹出数据。
例如,POP AX将从栈中弹出的数据存储到AX寄存器中。
算术指令用于执行算术操作,例如加法、减法、乘法和除法。
下面是一些常用的算术指令:1. ADDADD指令用于将两个数相加,并将结果存储在指定的位置。
例如,ADD AX, BX将AX和BX寄存器中的值相加,并将结果存储在AX寄存器中。
2. SUBSUB指令用于将第二个操作数的值从第一个操作数的值中减去,并将结果存储在指定的位置。
例如,SUB AX, BX从AX寄存器中减去BX寄存器的值,并将结果存储在AX寄存器中。
3. MULMUL指令用于将两个数相乘,并将结果存储在指定的位置。
例如,MUL AX, BX将AX和BX寄存器中的值相乘,并将结果存储在AX寄存器中。
4. DIVDIV指令用于将第一个操作数的值除以第二个操作数的值,并将商存储在第一个操作数指定的位置,余数存储在指定的位置。
例如,DIV AX, BX将AX寄存器中的值除以BX寄存器的值,并将商存储在AX寄存器中,余数存储在DX寄存器中。
逻辑指令用于执行逻辑操作,例如与、或、非和异或等。
下面是一些常用的逻辑指令:1. ANDAND指令用于对两个操作数进行按位与操作,并将结果存储在指定的位置。
汇编语言指令汇总
汇编语言指令汇总汇编语言是一种底层编程语言,用于编写计算机程序。
在汇编语言中,指令是执行特定操作的基本单元。
以下是一些常见的汇编语言指令的汇总:1.数据传输指令:-MOV:将源操作数的值复制到目的操作数。
-PUSH:将数据压入栈中。
-POP:从栈中弹出数据。
-LEA:将源操作数的有效地址加载到目的操作数中。
2.算术和逻辑指令:-ADD:将两个操作数相加,结果存储在目的操作数中。
-SUB:将第二个操作数从第一个操作数中减去,结果存储在目的操作数中。
-MUL:将两个操作数相乘,结果存储在目的操作数中。
-DIV:将第一个操作数除以第二个操作数,商存储在目的操作数中。
3.分支和循环指令:-JMP:无条件跳转到指定的地址。
-CMP:比较两个操作数的值。
-JZ/JNZ:当比较结果为零/非零时,跳转到指定的地址。
-JE/JNE:当比较结果为相等/不相等时,跳转到指定的地址。
-JG/JGE/JL/JLE:当比较结果为大于/大于等于/小于/小于等于时,跳转到指定的地址。
-LOOP:循环指令,根据计数寄存器的值重复执行指定的代码块。
4.中断指令:-INT:引发中断,将程序控制权转移到中断服务程序。
-IRET:从中断服务程序返回到调用程序。
5.位操作指令:-AND/OR/XOR:按位与/或/异或操作。
-NOT:按位取反操作。
-SHL/SHR:逻辑左移/逻辑右移操作。
6.I/O指令:-IN:从输入端口读取数据。
-OUT:向输出端口写入数据。
7.标志位操作指令:-CLC:清除进位标志位。
-STC:设置进位标志位。
-CLI:禁用中断。
-STI:启用中断。
8.字符串指令:-MOVS:将一个字符串从源地址移动到目的地址。
-CMPS:比较两个字符串的内容。
-LODS:从源地址加载一个字符或一个字符串。
-STOS:存储一个字符或一个字符串到目的地址。
9.其他指令:-NOP:空操作指令。
-HLT:停止运行指令。
以上只是一些常见的汇编语言指令,汇编语言的指令集因计算机体系结构而异。
微机原理指令总结
1.内部数据传送指令:(1)以累加器A为目的操作数的指令功能:将源操作数指定的内容送入累加器A。
MOV A , Rn ; A ←(Rn)MOV A , direct ; A ←(direct)MOV A , @Ri ; A ←((Ri))MOV A , # data ; A ← data(2)以Rn为目的操作数的指令功能:将源操作数所指定的内容送入当前工作寄存器R0 ~R7中。
MOV Rn , A ; Rn ← (A)MOV Rn , direct ; Rn ←(direct)MOV Rn , # data ; Rn ← data(3)以直接地址为目的操作数的指令功能:将源操作数所指定的内容送入由直接地址指出的片内RAM单元。
MOV direct , A ; (direct)← (A)MOV direct , Rn ; (direct) ← (Rn)MOV direct , direct ; (direct) ← (direct)MOV direct , @Ri ; (direct) ←((Ri))MOV direct , # data ; (direct) ← data4)以间接地址为目的操作数的指令功能:将源操作数所指定的内容送入R0/R1所指向片内RAM的存储单元中。
MOV @Ri , A ; (Ri) ← (A)MOV @Ri , direct ; (Ri) ← (direct)MOV @Ri , # data ; (Ri) ← data(5)16位数据传送指令唯一的一条16位立即数传送指令。
功能:将16位二进制的立即数送入数据指针DPTR中。
其中高8位送入DPH,低8位送入DPL。
MOV DPTR , # data162.外部数据传送指令MOVX A,@RiMOVX A,@DPTRMOVX @Ri,AMOVX @DPTR,A3.堆栈操作指令压栈指令:将direct中的内容送入堆栈中PUSH direct ;SP←(SP)+1,(SP)←(direct)出栈指令:将堆栈中的内容送回到direct中POP direct ; (direct) ← (SP), SP←(SP)-14.查表指令MOVC A,@A+DPTR;A←((A)+(DPTR))MOVC A,@A+PC ;PC ← (PC)+1, A←((A)+(PC))5.交换指令XCH A,Rn ;(A)←→(Rn)XCH A,direct ;(A)←→(direct)XCH A,@Ri ;(A)←→((Ri))XCHD A,@Ri ;(A0~3)←→((Ri)0~3)SWAP A ;(A0~3)←→(A4~7)6.逻辑操作类指令:逻辑“与”指令ANL逻辑“或”指令ORL逻辑“异或”指令XRL累加器A的清零和取反CLR CPL7.控制转移类指令长转移指令LJMP 标号绝对转移指令AJMP 标号短(相对)转移指令SJMP 标号间接转移指令JMP @A+DPTR8.累加器A的移位指令循环左移RL A ;循环右移RR A ;带进位位循环左移RLC A ;带进位位循环右移RRC A9.条件转移指令累加器判零转移指令JZ 标号JNZ 标号比较不等转移指令CJNE A, #data, 标号CJNE A, direct, 标号CJNE Rn, #data,标号CJNE @Ri, #data,标号减1不为零(循环)转移指令DJNZ Rn,标号DJNZ direct, 标号。
微机——微机原理指令汇总情况
微机——微机原理指令汇总情况微机原理指令是计算机中执行的最基本的操作。
它们是一条条的机器代码,用于告诉计算机要执行的操作。
微型计算机通过使用特定的指令集,可以执行各种不同的任务。
本文将对微机原理指令进行汇总和分类,以便更好地了解微机原理。
1. 数据传输指令(Data Transfer Instructions):用于将数据从一个位置传送到另一个位置。
- MOV(Move):将一个寄存器或内存的内容复制到另一个位置。
- XCHG(Exchange):交换两个操作数的值。
- PUSH(Push):将数据压入栈中。
- POP(Pop):从栈中弹出数据。
2. 运算指令(Arithmetic Instructions):用于执行一些基本的算术和逻辑运算。
- ADD(Addition):将两个操作数相加。
- SUB(Subtraction):将第一个操作数减去第二个操作数。
- MUL(Multiplication):将两个操作数相乘。
- DIV(Division):将第一个操作数除以第二个操作数。
- INC(Increment):将操作数加一- DEC(Decrement):将操作数减一3. 逻辑指令(Logical Instructions):用于执行一些逻辑运算。
- AND(And):对两个操作数进行逻辑与操作。
-OR(Or):对两个操作数进行逻辑或操作。
- XOR(Exclusive Or):对两个操作数进行异或操作。
- NOT(Not):对操作数进行逻辑非操作。
- SHR(Shift Right):对操作数进行右移操作。
- SHL(Shift Left):对操作数进行左移操作。
4. 跳转指令(Jump Instructions):用于控制程序的跳转。
- JMP(Jump):无条件跳转到指定的地址。
- JZ(Jump if Zero):如果上一个比较指令结果为零,则跳转到指定地址。
- JNZ(Jump if Not Zero):如果上一个比较指令结果不为零,则跳转到指定地址。
微机原理指令大全
微机原理指令大全微机原理是计算机科学中的重要基础知识,而指令则是微机原理中的核心内容之一。
指令是计算机中的基本操作命令,它直接影响着计算机的运行和执行效率。
本文将为大家详细介绍微机原理中常见的指令,并提供一份完整的指令大全,希望能够帮助大家更好地理解和掌握微机原理中的指令知识。
一、数据传送指令。
数据传送指令是微机原理中最基本的指令之一,它用于将数据从一个地方传送到另一个地方。
常见的数据传送指令包括MOV、LDM、STM等。
这些指令可以实现寄存器之间、寄存器和内存之间、内存和输入输出设备之间的数据传送操作,是计算机程序中不可或缺的一部分。
二、算术运算指令。
算术运算指令用于进行各种数值计算操作,包括加法、减法、乘法、除法等。
常见的算术运算指令有ADD、SUB、MUL、DIV等。
这些指令可以对寄存器和内存中的数据进行各种算术运算,是计算机程序中常用的指令之一。
三、逻辑运算指令。
逻辑运算指令用于进行各种逻辑操作,包括与、或、非、异或等。
常见的逻辑运算指令有AND、OR、NOT、XOR等。
这些指令可以对寄存器和内存中的数据进行逻辑运算,是计算机程序中实现逻辑判断和控制流程的重要指令之一。
四、转移指令。
转移指令用于改变程序的执行顺序,包括无条件转移和条件转移两种。
常见的转移指令有JMP、JZ、JNZ、JC、JNC等。
这些指令可以实现程序的跳转和循环控制,是计算机程序中实现各种复杂逻辑的重要指令之一。
五、比较指令。
比较指令用于比较两个数据的大小关系,常见的比较指令有CMP、TEST等。
这些指令可以对寄存器和内存中的数据进行比较操作,并根据比较结果设置标志位,是实现条件转移和逻辑判断的重要指令之一。
六、输入输出指令。
输入输出指令用于实现计算机与外部设备的数据交换,包括输入数据和输出数据两种操作。
常见的输入输出指令有IN、OUT等。
这些指令可以实现计算机与外部设备之间的数据传输,是计算机程序中实现输入输出功能的重要指令之一。
微机原理指令整理
类别指令类型指令名称指令缩写指令功能影响标志格式格式含义源操作数目的操作数传送指令通用传输指令基本传输指令MOV将源操作数中的数据传送至目的操作数,以实现寄存器与寄存器、寄存器与存储器之间数据传送以及立即数送往寄存器或存储器无1.MOV WORD PTR[2000],AX将AX送2000和2001单元(低位在低地址,高位在高地址,下同)至少有一个是寄存器(除立即数送存储器外);不能在两个存储单元之间直接传送数据;不能在两个段寄存器之间直接传送数据;不能将立即数直接送至段寄存器;SS和SP赋2.MOV AX,ES:[BX+SI+50]将ES段(BX+SI+50)字单元内容送AX3.MOV SS,BX将BX内容送SS4.MOV ES,SS:[DI+200]将SS段(DI+200)可编辑文本字单元内容送ES值必须紧邻指令指针IP既不作目的操作数也不做源操作数5.MOV BX,CX将CS内容送BX6.MOV WORD PTR [BX+DI],SS 将SS内容送(BX+DI)字单元CS不能作目的操作数;立即数不能作目的操作数7.MOV CL,DH将DH内容送CL8.MOV DI,[SI+100]将(SI+100)字单元内容送DI9.MOV WORD PTR [DI],DX 将DX内容送(DI)字单元10.MOV CX,3330立即数3330送CX可编辑文本11.MOV BYTE PTR [DI],0立即数0送(DI)字节单元堆栈操作指令PUSH将来自通用寄存器、段寄存器或存储单元的一个字(16位)内容压入堆栈(SP指向的栈顶个单元)无1.PUSH AX AX内容进栈通用寄存器、段寄存器、存储单元的一个字CS不能作目的操作数;2.PUSH SI SI内容进栈3.PUSH ES ES内容进栈4.PUSH CS CS内容进栈5.PUSH WORD PTR [BX](BX)和(BX+1)单元内容进栈6.PUSH WORD PTRBETA [BX](BX+BETA)字单元内容进栈不能使用8位源或目的操作数POP将栈顶个单元的内容退出(弹出)到通用寄存器、段寄存器或存储单无 1.POP BX栈顶2个字节出栈到BX不能使用8位源或目的操作数可编辑文本元2.POP DX栈顶2个字节出栈到DX 通用寄存器、段寄存器、存储单元的一个字节;CS不能作目的操作数3.POP ES栈顶2个字节出栈到ES4.POP SS栈顶2个字节出栈到SS5.POP [BX+50]栈顶2个字节出栈到(BX+50)字单元6.POP [BP+DI]栈顶2个字节出栈到(BP+DI)字单元交换指令XCHG实现数据宽度相同的源操作数与目无 1.XCHG AL,BL AL与BL之间字段寄存器、CS、IP、立可编辑文本的操作数之间的数据交换,亦即同为8位或16位的累加器与寄存器、寄存器与寄存器以及寄存器与存储单元之间的数据交换节交换即数不能作为源或目的操作数;两个存储单元之间、段寄存器与段寄存器之间不能进行交换2.XCHG CX,AXCX与AX之间字交换3.XCHG DH,CLDH与CL之间字节交换4.XCHG BX,CXBX与CX之间字交换5.XCHG BL,[1000]BL与1000单元内容字节交换6.XCHG WORD PTR[DI],DX(DI)字单元内容与DX字交换专换码指令XLAT专门使用累加器AL并将其中的值无MOV 设置SEGCODE有操作码,无操作数。
微机原理全部指令用法
一、机械码,又称机器码、ultraedit打开,编辑exe文件时您会瞧到许许多多得由0,1,2,3,4,5,6,7,8,9,A,B,C,D,E,F组成得数码,这些数码就就是机器码、修改程序时必须通过修改机器码来修改exe文件、二、需要熟练掌握得全部汇编知识(只有这么多)不大容易理解,可先强行背住,混个脸儿熟,以后慢慢得就理解了cmp a,b 比较a与bmov a,b 把b得值送给aret 返回主程序nop 无作用,英文“no operation”得简写,意思就是“do nothing”(机器码90)***机器码得含义参瞧上面(解释:ultraedit打开编辑exe文件时您瞧到90,等同于汇编语句nop)call 调用子程序je 或jz 若相等则跳(机器码74 或0F84)jne或jnz 若不相等则跳(机器码75或0F85)jmp 无条件跳(机器码EB)jb 若小于则跳ja 若大于则跳jg 若大于则跳jge 若大于等于则跳jl 若小于则跳jle 若小于等于则跳pop 出栈push 压栈三、常见修改(机器码)74=>75 74=>90 74=>EB75=>74 75=>90 75=>EBjnz>nop75>90(相应得机器码修改)jnz > jmp75 > EB(相应得机器码修改)jnz > jz75>74 (正常) 0F 85 > 0F 84(特殊情况下,有时,相应得机器码修改)四、两种不同情况得不同修改方法1、修改为jmpje(jne,jz,jnz) =>jmp相应得机器码EB (出错信息向上找到得第一个跳转)jmp得作用就是绝对跳,无条件跳,从而跳过下面得出错信息xxxxxxxxxxxx 出错信息,例如:注册码不对,sorry,未注册版不能…,”Function Not Avaible in Demo” 或”mand Not Avaible” 或”Can’t save in Shareware/Demo”等(我们希望把它跳过,不让它出现)。
微机原理——指令表V2.0汇编
1MOV 通用数据传送指令MOV格式:MOV dest,src指令功能:将操作数src复制传送到操作数dest,即src→dest备注:有时MASM不能确定内存操作数的类型,需要用byte ptr和word ptr明确指出字节货字节类型说明:一:目的操作数不可以是立即数,源和目的操作数支持所有的寻址方式二:(1)所有的MOV传送指令的不改变标致寄存器FR的标志位。
(2)代码段的段基址和偏移地址寄存器CS,IP不能作为目的操作数。
例如“MOV CS,AX”是错误指令。
(3)两个段寄存器间的数据不能直接传送。
例如“MOV DS,SS”就是错误的指令。
(4)立即数不能直接传送给段寄存器。
例如“MOV DS, 2000H”就是错误的指令,如果要进行这样的操作,可间接完成MOV AX, 2000HMOV DS, AX(5)两个操作数不能同时为内存单元的数据,即内存单元的数据不能直接传送。
例如“MOV [DI],[SI]”就是错误的指令,间接完成:MOV AX,[SI]MOV [DI],AX(6)立即数不能作为目的操作数,例如“MOV 1000H,AX”就是错误的指令。
(7)所传送的源和目的的操作数的数据位数必须一致。
例如“MOVBX,AL”就是错误的指令,BX的数据位数为16位,而AL为8位,传送的数据不匹配。
2PUSH 入栈指令PUSH格式:PUSH OPRD指令功能:将指定的寄存器或存储单元的内容存入到栈顶实现压入操作的是PUSH,实现弹出操作指令是POP注意:(1)操作数OPRD不可以是立即数;(2)入栈的数据必须是16位的,且支持所有寻址方式入栈过程:第一步:SP—1→SP,然后操作数的高位字节送至SP所指向的单元;第二部:SP—1→SP,然后操作数的低位字节送至SP所指向的单元;3POP 出栈指令POP格式:POP OPRD指令功能:将栈顶的数据复制到指定的寄存器或内存单元中。
注意:(1)操作数不可以是CS寄存器;(2)出栈的数据必须是16位的,且支持所有的寻址方式出栈的顺序与入栈顺序相反,其过程分以下两步:第一步:SP所指向单元的数据送至操作数的低位字节,SP+1→SP;第二部:SP所指向单元的数据送至操作数的高位字节,SP+1→SP;4PUSHF 标志进栈指令PUSHF指令功能:将标志寄存器FR的内容存入到栈顶。
微机原理汇编常用指令
1) ADD 加法指令汇编格式:ADD 目的操作数,源操作数执行的操作:(目的操作数)←源操作数+目的操作数2) ADC 带进位加法指令汇编格式:ADC 目的操作数,源操作数执行的操作:(目的操作数)←源操作数+目的操作数+CF3) INC 增量指令汇编格式:INC 操作数执行的操作:(操作数)←操作数+1PS:以上三条指令都可作字或字节运算,除INC指令不影响CF标志位外,其他标志位都受指令操作结果的影响。
4) SUB 减法指令汇编格式:SUB 目的操作数,源操作数执行的操作:(目的操作数)←目的操作数-源操作数5) SBB 带借位减法指令汇编格式:SBB 目的操作数,源操作数执行的操作:(目的操作数)←目的操作数-源操作数-CF6) DEC 减量指令汇编格式:DEC 操作数执行的操作:(操作数)←操作数-17) NEG 求补指令汇编格式:NEG 操作数执行的操作:(操作数)←0-操作数8) CMP比较指令汇编格式:CMP 目的操作数,源操作数执行的操作:目的操作数-源操作数。
PS:以上五条指令都可作字或字节运算。
另外,除DEC指令不影响CF标志位外,其他指令都对标志位有影响。
9) MUL 无符号数乘法指令汇编格式:MUL 源操作数执行的操作:若为字节操作(AX)←(AL)×源操作数若为字操作(DX), (AX)←(AX)×源操作数10) IMUL 有符号数乘法指令汇编格式:IMUL 源操作数执行的操作:与MUL相同,只是处理的数据是有符号数,而MUL处理的数据是无符号数。
11) DIV 无符号数除法指令汇编格式:DIV 源操作数执行的操作:若为字节操作:(AL)←(AX)/源操作数的商(AH)←(AX)/源操作数的余数若为字操作:(AX)←(DX、AX)/源操作数的商(DX)←(DX、AX)/源操作数的余数商和余数均为无符号数。
12) IDIV 有符号数除法指令汇编格式:IDIV 源操作数执行的操作:与DIV相同,只是操作数是有符号数,商和余数均为有符号数,余数符号同被除数符号。
微型计算机汇编指令大全
数据传送指令集MOV功能: 把源操作数送给目的操作数语法: MOV 目的操作数,源操作数格式: MOV r1,r2MOV r,mMOV m,rMOV r,dataXCHG功能: 交换两个操作数的数据语法: XCHG格式: XCHG r1,r2 XCHG m,r XCHG r,mPUSH,POP功能: 把操作数压入或取出堆栈语法: PUSH 操作数POP 操作数格式: PUSH r PUSH M PUSH data POP r POP mPUSHF,POPF,PUSHA,POPA功能: 堆栈指令群格式: PUSHF POPF PUSHA POPALEA,LDS,LES功能: 取地址至寄存器语法: LEA r,m LDS r,m LES r,mXLAT(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,OSUB,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,OINC,DEC功能: 把OP的值加一或减一语法: INC OP DEC OP格式: INC r/m DEC r/m影响标志: P,A,Z,S,ONEG功能: 将OP的符号反相(取二进制补码)语法: NEG OP格式: NEG r/m影响标志: C,P,A,Z,S,OMUL,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/mCBW,CWD功能: 有符号数扩展指令语法: CBW CWDAAA,AAS,AAM,AAD功能: 非压BCD码运算调整指令语法: AAA AAS AAM AAD影响标志: A,C(AAA,AAS) S,Z,P(AAM,AAD)DAA,DAS功能: 压缩BCD码调整指令语法: DAA DAS影响标志: C,P,A,Z,S位运算指令集AND,OR,XOR,NOT,TEST功能: 执行BIT与BIT之间的逻辑运算语法: AND r/m,r/m/data OR r/m,r/m/data XOR r/m,r/m/data TEST r/m,r/m/data NOT r/m 影响标志: C,O,P,Z,S(其中C与O两个标志会被设为0) NOT指令不影响任何标志位SHR,SHL,SAR,SAL功能: 移位指令语法: SHR r/m,data/CL SHL r/m,data/CL SAR r/m,data/CL SAL r/m,data/CL影响标志: C,P,Z,S,OROR,ROL,RCR,RCL功能: 循环移位指令语法: ROR r/m,data/CL ROL r/m,data/CL RCR r/m,data/CL RCL r/m,data/CL 影响标志: C,P,Z,S,O程序流程控制指令集CLC,STC,CMC功能: 设定进位标志语法: CLC STC CMC标志位: CCLD,STD功能: 设定方向标志语法: CLD STD标志位: DCLI,STI功能: 设定中断标志语法: CLI STI标志位: ICMP功能: 比较OP1与OP2的值语法: CMP r/m,r/m/data标志位: C,P,A,Z,OJMP功能: 跳往指定地址执行语法: JMP 地址JXX功能: 当特定条件成立则跳往指定地址执行语法: JXX 地址注:A: ABOVE,当C=0,Z=0时成立B: BELOW,当C=1时成立C: CARRY,当弁时成立CXZ: CX寄存器的值为0(ZERO)时成立E: EQUAL,当Z=1时成立G: GREATER(大于),当Z=0且S=0时成立L: LESS(小于),当S不为零时成立N: NOT(相反条件),需和其它符号配合使用O: OVERFLOW,O=1时成立P: PARITY,P=1时成立PE: PARITY EVEN,P=1时成立PO: PARITY ODD,P=0时成立S: SIGN,S=1时成立Z: ZERO,Z=1时成立LOOP功能: 循环指令集语法: LOOP 地址LOOPE(Z)地址LOOPNE(Z) 地址标志位: 无CALL,RET功能: 子程序调用,返回指令语法: CALL 地址RET RET n标志位: 无INT,IRET功能: 中断调用及返回指令语法: INT n IRET标志位: 在执行INT时,CPU会自动将标志寄存器的值入栈,在执行IRET时则会将堆栈中的标志值弹回寄存器字符串操作指令集MOVSB,MOVSW,MOVSD功能: 字符串传送指令语法: MOVSB MOVSW MOVSD标志位: 无CMPSB,CMPSW,CMPSD功能: 字符串比较指令语法: CMPSB CMPSW CMPSD标志位: C,P,Z,S,OSCASB,SCASW功能: 字符串搜索指令语法: SCASB SCASW标志位: C,P,Z,S,OLODSB,LODSW,STOSB,STOSW功能: 字符串载入或存贮指令语法: LODSB LODSW STOSB STOSW标志位: 无REP,REPE,REPNE功能: 重复前缀指令集语法: REP 指令S REPE 指令S REPNE 指令S标志位: 依指令S而定对于IBM PC机它有它的指令系统,其中包括:数据传送指令、串处理指令、算术指令、控制移动指令、逻辑指令、处理机控制指令。
汇编语言常用指令大全解释
汇编语言常用指令大全解释汇编语言常用指令大全解释常用汇编指令:MOV指令为双操作数指令,两个操作数中必须有一个是寄存器.MOV DST , SRC // Byte / Word执行操作: dst = src1.目的数可以是通用寄存器, 存储单元和段寄存器(但不允许用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=Tmp1.必须有一个操作数是在寄存器中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_ONEMOV SP , [BX] //将BX间接寻址的相继的二个存储单元的内容送入SP中LEA SP , [BX] //将BX的内容作为存储器有效地址送入SP中LDS(Load DS with pointer)指针送寄存器和DS指令LDS REG , SRC //常指定SI寄存器。
微机原理指令表和解释
LDS DEST,SRC;DSET(16位通用寄存器)[SRC](第一个字的内容)
DS [SRC](第二个字的内容)
LES DEST,SRC;DSET(16位通用寄存器)[SRC](第一个字的内容)
ES [SRC](第二个字的内容)
7.输入输出指令
SCL DEST,COUNT;带进位循环左移带CF一起的循环
SCR DEST,COUNT;带进位循环右移带CF一起的循环
12.基本串操作类指令
MOVSB;(字节传送)ES:[DI] DS:[SI] SI [SI+-1] DI [DI+-1]
MOVSW;(字传送)ES:[DI] DS:[SI] SI [SI+-2] DI [DI+-2]
REPNZ;每执行依次串指令CX(CX)-1 CX=0或ZF=1重复执行结束
14.无条件转移类指令
JMP DEST;无条件转移到DEST所指定的地址
15.循环指令
LOOP DEST;CXCX)-1直至CX=0结束循环
LOOPE/LOOPZ DEST;CXCX)-1直至CX=0或ZF=0结束循环
LOOPNE/LOOPNZ DEST;CXCX)-1直至CX=0或ZF=1结束循环
取串指令
LODSB;(字节传送)AL DS:[SI] SI [SI+-1]
LODSW;(字传送)AL DS:[SI] SI [SI+-2]
存串指令
STOSB;(字节传送)ES:[DI] AL DI [DI+-1]
STOSW;(字传送)ES:[DI] AX DI [DI+-2]
串比较指令
微机原理指令集合
微机原理指令集合微机原理8086指令集合地址总线:AB(单向输出)数据总线:DB(双向总线)控制总线:CB(输出输入或双向)4个16位数据寄存器:AX累加器.BX基址寄存器.CX计数寄存器.DX数据寄存器高八位记作:AH.BH.CH.DH低八位ALBLCLDL指针寄存器:SP 堆栈指针寄存器BP基址指针寄存器变址寄存器:SI 源变址寄存器(源操作数偏移地址)DI目的变址寄存器状态位:CF、PF、AF、ZF、SF、OF(6位,操作结果的特征)控制位:TF、IF、DF进位标志位:CF最高位奇偶标志位:PF低8位1的个数为偶时为1辅助进位标志位:AF低4位向高4为有进位时为1零标志位:ZF算术逻辑运算为零时为1符号标志位:SF运算结果(负数)最高位为1时为1溢出标志位:OF结果超出有符号数补码表示的范围时为1 (字节数据-128~+127,字数据-32768~+32767)跟踪标志位:TF单步中断方式逐条检查方向标志位:DF中断允许标志位:IF为1时CPU可以响应可屏蔽中断(INTR)请求立即数寻址:MOV BL,5BH寄存器寻址:MOV DS,AX存储器寻址:1直接寻址:MOV AX,[2000H]2寄存器间接寻址:MOV AX,[BP]操作数有效地址在BX,BP,SI,DI,当在BX ,SI,DI中默认DS为基址,在BP中默认SS为基址3寄存器相对寻址:MOV AX,COUNT[SI]例:MOV BP:[DI+45H]4基址加变址寻址:MOV AX, [SI+BP]5相对基址加变址寻址指令MOV AX, [SI+BP+1234H]指令P61数据传送P70算数逻辑P83逻辑运算和移位P88字符串操作P92控制转移P93无条件转移P101直接标志条件转移P102间接标志条件转移P103标志操作(概括)数据传送指令通用数据传送指令:MOV/PUSH/POP/XCHG/XLAT输入输出指令:IN/OUT地址目标传送指令:LEA/LDS/LES标志传送指令:LAHF/SAHF/PUSHF/POPF算术逻辑指令加法:ADD/ADC/INC/AAA/DAA减法:SUB/SBB/DEC/NEG/C,P/AAS/DAS乘法:MUL/IMUL/AAM,除法:DIV/IDIV/AAD/CBW/CWD逻辑运算和移位指令逻辑运算:NOT/AND/OR/XOR/TEST算术逻辑移位:SHL/SHR/SAL/SAR循环移位:ROL/ROR/RCL/RCR字符串操作指令MOVS/CMPS/SCAS/LODS/STOSMOVSB/CMPSB/SCASB/LODSB/STOSB控制转移指令JMP/CALL/RET/JZ/JE/JA/JNBE/LOOP/LOOPE/LOOPZ/LOOPNE/LOOPNZ/JCXZ/IN T/INTO/IRET无条件转移指令段内转移直接(8位)JMP SHORT PROG_S (16位)JMP NEARPTR/PROG_N间接(8位)JMP BX (16位)JMP WORD PTR 5[BX]段间转移直接(32位)JMP FAR PTR PROG_F/JMP DWORD PTR[DI]直接标志条件转移JC/JNC/JZ/JE/JNZ/JNE/JS/JNS/JO/JNO/JP/JPE/JNP/JPO间接标志条件转移JA/JNBE/JAE/JNB/JB/JNAE/JBE/JNA/JG/JNLE/JGE/JNL/JL/JNGE/JLE/JNG(较详)数据传送指令MOV dst,src交换指令:XCHG dst,src查表指令:XLAT[表首址]DS:(BX+AL)给AL进栈指令:PUSH src(sp←sp-2)出栈指令:POP src (sp←sp+2)取有效地址指令;LEA dst,src指针送寄存器和DS:LDS dst,src指针送寄存器和ES:LES dst,src标志传送指令:LAHFSAHF PUSHF POPF输入、输出指令:IN、OUT加法指令:ADD dst,src带进位加法指令:ADC dst,src (CF也要加)目的操作数加1指令:INC dst加法ASCII调整指令:AAA加法的十进制调整指令:DAA减法指令:SUB dst,src带借位减法指令:SBB dst,src(也要减CF)减1指令:DEC src111取负指令:NEG src(0减src)比较指令:CMP dst,src(目减源,结果不会送到目的,结果仅反应在标志位无符号看CF有符号看SF)乘法指令:无符号数乘法指令MUL src字节操作数:AL*src给AX或src字操作数:AX*src给AX整数乘法指令:IMUL src字运算AX字节运算AL乘法的ASCII调整指令:AAM除法指令:DIV src字节将AX除以src给AL余数该AH/src 字将(DX,AX)除以src给AX余数给DX整数除法指令:IDIV srcCBW 将字节转换为字CWD将字转换为字节逻辑运算:逻辑与:AND dst,src逻辑或:OR dst,src非:NOT dst异或:XOR dst,src测试:TEST dst,src(测试判断某些位知否同时为0)移位指令(左移一次相当于乘2,最高位进入标志位CF;右移一次相当于除以2,最低位进入标志位)算术左移指令SAL dst, CL;移位位数逻辑左移指令SHL dst ,CL;移位位数算术右移指令:SAR dst ,CL;移位位数逻辑右移指令:SHR dst,CL ;移位位数循环移位指令:循环左移指令:ROL dst,CL;移位位数循环右移指令:ROR dst,CL;移位位数带进位循环左移:RCL dst,CL;移位位数带进位循环右移:RCR dst,CL;移位位数串操作指令:串传送指令:MOVS/W串比较指令:CMPSB/W串搜索指令:SCASB/W取串指令:LODS/W存串指令:STOSB/W重复前缀指令:REP SOPR 重复执行REP指令后紧跟着的一个串操作指令,知直到CX寄存器中的值为0 REPE/REPZ执行REPE/REPZ后紧跟的一个串操作指令,当相等、为0时重复,直到CX=0/ZF=0 REPNE/REPNZ 执行REPNE/REPNZ后紧跟的串操作指令当不为0、不相等时重复,直到CX=0/ZF=0转移指令:远程转移:JMP FAR PTR OPRD(IP=IP+16位移量)近程转移:JMP NEAR PTR OPRD (IP=IP+8位移量)段内间接转移:JMP reg16JMP men16(IP)←reg16或men16段间间接转移:JMP DWORD PTR [BX+SI]调用和返回指令:段内直接调用:CALL dst(SP=SP-2,SP+1,IP指向SP,IP=IP+16段内直接调用:CALL dst(同,同,EA指向IP)段间直接调用:CALL dst(SP=SP-2,SP+1,CS指向SP,SP=SP-2,SP+1,IP指向SP,偏移地址指向IP,段地址指向CS)段间间接调用:CALL dst段内返回:RET(IP=SP+1,SP,SP=SP+2)段内带立即数返回:RET n循环控制指令:LOOP OPRD(CX=CX-1,若CX≠0则循环LOOPNZ/LOOPE OPRD(CX=CX-1,若CX≠0ZF=0则循环)LOOPZ/LOOPEOPRD。
微机原理指令汇总
我现将指令系统中各种助记符的英文全名写出来,各种助记符的记忆就会变得很简单o(∩_∩)o...在这之前,先说一下寄存器:数据寄存器分为:AH&AL=AX(accumulator):累加寄存器,常用于运算;在乘除等指令中指定用来存放操作数,另外,所有的I/O指令都使用这一寄存器与外界设备传送数据.BH&BL=BX(base):基址寄存器,常用于地址索引;CH&CL=CX(count):计数寄存器,常用于计数;常用于保存计算值,如在移位指令,循环(loop)和串处理指令中用作隐含的计数器.DH&DL=DX(data):数据寄存器,常用于数据传递。
他们的特点是,这4个16位的寄存器可以分为高8位: AH, BH, CH, DH.以及低八位:AL,BL,CL,DL。
这2组8位寄存器可以分别寻址,并单独使用。
另一组是指针寄存器和变址寄存器,包括:SP(Stack Pointer):堆栈指针,与SS配合使用,可指向目前的堆栈位置;BP(Base Pointer):基址指针寄存器,可用作SS的一个相对基址位置;SI(Source Index):源变址寄存器可用来存放相对于DS段之源变址指针;DI(Destination Index):目的变址寄存器,可用来存放相对于ES 段之目的变址指针。
指令指针IP(Instruction Pointer)标志寄存器FR(Flag Register)OF(overflow flag)DF(direction flag)CF(carrier flag)PF(parity flag)AF(auxiliary flag)ZF(zero flag)SF(sign flag)IF(interrupt flag)TF(trap flag)段寄存器(Segment Register)为了运用所有的内存空间,8086设定了四个段寄存器,专门用来保存段地址:CS(Code Segment):代码段寄存器;DS(Data Segment):数据段寄存器;SS(Stack Segment):堆栈段寄存器;ES(Extra Segment):附加段寄存器。
- 1、下载文档前请自行甄别文档内容的完整性,平台不提供额外的编辑、内容补充、找答案等附加服务。
- 2、"仅部分预览"的文档,不可在线预览部分如存在完整性等问题,可反馈申请退款(可完整预览的文档不适用该条件!)。
- 3、如文档侵犯您的权益,请联系客服反馈,我们会尽快为您处理(人工客服工作时间:9:00-18:30)。
1) ADD 加法指令
汇编格式:ADD 目的操作数,源操作数
执行的操作:(目的操作数)←源操作数+目的操作数
2) ADC 带进位加法指令
汇编格式:ADC 目的操作数,源操作数
执行的操作:(目的操作数)←源操作数+目的操作数+CF
3) INC 增量指令
汇编格式:INC 操作数
执行的操作:(操作数)←操作数+1
PS:以上三条指令都可作字或字节运算,除INC指令不影响CF标志位外,其他标志位都受指令操作结果的影响。
4) SUB 减法指令
汇编格式:SUB 目的操作数,源操作数
执行的操作:(目的操作数)←目的操作数-源操作数
5) SBB 带借位减法指令
汇编格式:SBB 目的操作数,源操作数
执行的操作:(目的操作数)←目的操作数-源操作数-CF
6) DEC 减量指令
汇编格式:DEC 操作数
执行的操作:(操作数)←操作数-1
7) NEG 求补指令
汇编格式:NEG 操作数
执行的操作:(操作数)←0-操作数
8) CMP比较指令
汇编格式:CMP 目的操作数,源操作数
执行的操作:目的操作数-源操作数。
PS:以上五条指令都可作字或字节运算。
另外,除DEC指令不影响CF标志位外,其他指令都对标志位有影响。
9) MUL 无符号数乘法指令
汇编格式:MUL 源操作数
执行的操作:若为字节操作(AX)←(AL)×源操作数
若为字操作(DX), (AX)←(AX)×源操作数
10) IMUL 有符号数乘法指令
汇编格式:IMUL 源操作数
执行的操作:与MUL相同,只是处理的数据是有符号数,而MUL处理的数据是无符号数。
11) DIV 无符号数除法指令
汇编格式:DIV 源操作数
执行的操作:若为字节操作:(AL)←(AX)/源操作数的商
(AH)←(AX)/源操作数的余数
若为字操作:(AX)←(DX、AX)/源操作数的商
(DX)←(DX、AX)/源操作数的余数
商和余数均为无符号数。
12) IDIV 有符号数除法指令
汇编格式:IDIV 源操作数
执行的操作:与DIV相同,只是操作数是有符号数,商和余数均为有符号数,余数符号同被除数符号。
1) AND逻辑与指令
汇编格式:AND 目的操作数,源操作数
执行的操作:(寻址到的目的地址)←目的操作数∧源操作数
2) OR逻辑或指令
汇编格式:OR 目的操作数,源操作数
执行的操作:(寻址到的目的地址)←目的操作数∨源操作数
3) XOR逻辑异或指令
汇编格式:XOR 目的操作数,源操作数
执行的操作:(寻址到的目的地址)←目的操作数∨源操作数
4) TEST测试指令
汇编格式:TEST 目的操作数,源操作数
执行的操作:目的操作数∧源操作数
5) NOT逻辑非指令
汇编格式:NOT 目的操作数
执行的操作:(寻址到的地址)←(操作数)
1) 逻辑移位指令
● SHL逻辑左移指令
汇编格式:SHL 除立即数及段寄存器之外的操作数,移位次数
● SHR逻辑右移指令
汇编格式:SHR 除立即数及寄存器之外的操作数,移位次数
2) 算术移位指令
● SAL算术左移指令
汇编格式:SAL 除立即数及段寄存器之外的操作数,移位次数
● SAR算术右移指令
汇编格式:SAR 除立即数及段寄存器之外的操作数,移位次数
3) 小循环移位指令
● ROL循环左移指令
汇编格式:ROL 除立即数和段寄存器之外的操作数,移位次数
● ROR循环右移指令
汇编指令:ROR 除立即数和段寄存器之外的操作数,移位次数
控制转移指令
1. 无条件转移指令JMP
JMP指令的功能就是无条件地转移到指令指定的地址去执行从该地址开始的指令序列。
汇编格式:JMP SHORT 转移地址标号
操作
汇编指令名测试条件
JZ(或JE) ZF=1 结果为零(或相等)则转移JNZ(或JNE) ZF=0 结果不为零(或不相等)则转移JS SF=1 结果为负则转移
JNS SF=0 结果为正则转移
JO OF=1 结果溢出则转移
JNO OF=0 结果无溢出则转移
JP(或JPE) PF=1 奇偶位为1则转移
JNP(或JPO) PF=0 奇偶位为0则转移
JC(或JNAE或JB) CF=1 有进位则转移
JNC(或JAE或JNB) CF=0 无进位则转移
以上是部分汇编指令,亲自打的。
最后应周骏康的要求,补充一下寄存器注意部分:
通用寄存器
●AX→(AH,AL)●AX:累加器。
多用于存放中间运算结果。
●BX→(BH,BL)●BX:基址寄存器。
在间接寻址中用于存放基地址;
●CX→(CH,CL)●CX:计数寄存器。
用于在循环或串操作指令中存放循环次数或重复次数;
●DX→(DH,DL)●DX:数据寄存器。
在32位乘除法运算时,存放高16位数;
指针和变址寄存器
●SP:堆栈指针寄存器,其内容为栈顶的偏移地址;
●BP:基址指针寄存器,常用于在访问内存时存放内存单元的偏移地址。
●SI:源变址寄存器
●DI:目标变址寄存器
变址寄存器常用于指令的间接寻址或变址寻址。
段寄存器
CS:代码段寄存器,代码段用于存放指令代码
DS:数据段寄存器
ES:附加段寄存器,数据段和附加段用来存放操作数
SS:堆栈段寄存器,堆栈段用于存放返回地址,保存寄存器内容,传递参数。