微机原理汇编常用指令
微机原理中部分指令列表汇总

条件转移指令指令助记符转移条件含义无符号数条件转移指令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有操作码,无操作数。
- 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:堆栈段寄存器,堆栈段用于存放返回地址,保存寄存器内容,传递参数。