x86汇编语言指令集
汇编语言基于x86处理器
汇编语言基于x86处理器
汇编语言是一种低级编程语言,用于与计算机硬件直接交互。
基于x86处理器的汇编语言主要用于编写针对x86架构的计算机程序。
x86处理器是一种广泛使用的处理器架构,包括Intel和AMD 等厂商生产的多个处理器系列。
在x86汇编语言中,程序员使用特定的指令集来操作寄存器、内存和其他硬件设备,实现计算机指令的精确控制和数据处理。
以下是一些基于x86处理器的汇编语言的特点和要点:
寄存器:x86处理器提供了多个通用寄存器,如AX、BX、CX、DX等,以及专用寄存器如指令指针寄存器IP、堆栈指针寄存器SP等。
程序员可以使用这些寄存器来存储数据、进行计算和操作。
指令集:x86汇编语言提供了广泛的指令集,包括数据传输、算术运算、逻辑运算、条件分支、循环控制等。
程序员可以使用这些指令来实现各种操作和算法。
内存访问:x86汇编语言可以直接访问内存,读取和写入数据。
程序员需要了解内存地址和数据类型的操作方式,以正确地操作内存中的数据。
栈操作:x86汇编语言中的栈用于存储局部变量、函数调用和
返回地址等信息。
程序员可以使用栈指针寄存器来管理栈,并使用相关指令进行入栈和出栈操作。
中断处理:x86处理器支持中断和异常处理机制。
程序员可以编写中断处理程序,以响应硬件中断或软件触发的异常情况。
编写基于x86处理器的汇编语言程序需要对x86架构的指令集和寄存器使用有深入的理解,以及对计算机硬件和操作系统的了解。
熟练掌握汇编语言的编写技巧和调试工具对于开发和调优x86汇编语言程序非常重要。
x86汇编指令集大全(带注释)
x86汇编指令集大全(带注释)X86和X87汇编指令大全(有注释)---------- 一、数据传输指令---------------------------------------------------- 它们在存贮器和寄存器、寄存器和输入输出端口之间传送数据. 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. NEG 求反(以 0 减之). CMP 比较.(两操作数作减法,仅修改标志位,不回送结果). AAS 减法的ASCII码调整. DAS 减法的十进制调整. MUL 无符号乘法.结果回送AH和AL(字节运算),或DX和AX(字运算), IMUL 整数乘法.结果回送AH和AL(字节运算),或DX和AX(字运算), AAM 乘法的ASCII码调整. DIV 无符号除法.结果回送:商回送AL,余数回送AH, (字节运算);或商回送AX,余数回送DX, (字运算). 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,04 SHL 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 封锁 ========== 浮点运算指令集========================================= ============= ---------- 一、控制指令(带9B的控制指令前缀F变为FN时浮点不检查,机器码去掉9B)---- FINIT 初始化浮点部件机器码 9B DB E3 FCLEX 清除异常机器码 9B DB E2 FDISI 浮点检查禁止中断机器码 9B DB E1 FENI 浮点检查禁止中断二机器码 9B DB E0 WAIT 同步CPU和FPU 机器码 9B FWAIT 同步CPU和FPU 机器码 D9 D0 FNOP 无操作机器码 DA E9 FXCH 交换ST(0)和ST(1) 机器码 D9 C9 FXCH ST(i) 交换ST(0)和ST(i) 机器码 D9 C1iii FSTSW ax 状态字到ax 机器码 9B DF E0 FSTSW word ptr mem 状态字到mem 机器码 9B DD mm111mmm FLDCW word ptr mem mem到状态字机器码 D9 mm101mmm FSTCW word ptr mem 控制字到mem 机器码 9B D9 mm111mmm FLDENV word ptr mem mem到全环境机器码 D9 mm100mmm FSTENV word ptr mem 全环境到mem 机器码 9B D9 mm110mmm FRSTOR word ptr mem mem到FPU状态机器码 DD mm100mmm FSAVE word ptr mem FPU状态到mem 机器码 9B DD mm110mmm FFREE ST(i) 标志ST(i)未使用机器码 DD C0iii FDECSTP 减少栈指针1->0 2->1 机器码 D9 F6 FINCSTP 增加栈指针0->1 1->2 机器码 D9 F7 FSETPM 浮点设置保护机器码 DB E4 ---------- 二、数据传送指令 ---------------------------------------------------- FLDZ 将0.0装入ST(0) 机器码 D9 EE FLD1 将1.0装入ST(0) 机器码 D9 E8 FLDPI 将π装入ST(0) 机器码 D9 EB FLDL2T 将ln10/ln2装入ST(0) 机器码 D9 E9 FLDL2E 将1/ln2装入ST(0) 机器码 D9 EA FLDLG2 将ln2/ln10装入ST(0) 机器码 D9 EC FLDLN2 将ln2装入ST(0) 机器码 D9 ED FLD real4 ptr mem 装入mem的单精度浮点数机器码 D9 mm000mmm FLD real8 ptr mem 装入mem的双精度浮点数机器码 DD mm000mmm FLD real10 ptr mem 装入mem的十字节浮点数机器码 DB mm101mmm FILD word ptr mem 装入mem的二字节整数机器码 DF mm000mmm FILD dword ptrmem 装入mem的四字节整数机器码 DB mm000mmm FILD qword ptr mem 装入mem的八字节整数机器码DF mm101mmm FBLD tbyte ptr mem 装入mem的十字节BCD数机器码 DF mm100mmm FST real4 ptr mem 保存单精度浮点数到mem 机器码D9 mm010mmm FST real8 ptr mem 保存双精度浮点数到mem 机器码DD mm010mmm FIST word ptr mem 保存二字节整数到mem 机器码 DF mm010mmm FIST dword ptr mem 保存四字节整数到mem 机器码 DB mm010mmm FSTP real4 ptr mem 保存单精度浮点数到mem并出栈机器码 D9 mm011mmm FSTP real8 ptr mem 保存双精度浮点数到mem并出栈机器码 DD mm011mmm FSTP real10 ptr mem 保存十字节浮点数到mem并出栈机器码DB mm111mmm FISTP word ptr mem 保存二字节整数到mem并出栈机器码DF mm011mmm FISTP dword ptr mem 保存四字节整数到mem并出栈机器码 DB mm011mmm FISTP qword ptr mem 保存八字节整数到mem并出栈机器码 DF mm111mmm FBSTP tbyte ptr mem 保存十字节BCD数到mem并出栈机器码 DF mm110mmm FCMOVB ST(0),ST(i) <时传送机器码 DA C0iii FCMOVBE ST(0),ST(i) <=时传送机器码DA D0iii FCMOVE ST(0),ST(i) =时传送机器码DA C1iii FCMOVNB ST(0),ST(i) >=时传送机器码DB C0iii FCMOVNBE ST(0),ST(i) >时传送机器码 DB D0iii FCMOVNE ST(0),ST(i) !=时传送机器码 DB C1iii FCMOVNU ST(0),ST(i) 有序时传送机器码 DB D1iii FCMOVU ST(0),ST(i) 无序时传送机器码 DA D1iii ---------- 三、比较指令 -------------------------------------------------------- FCOM ST(0)-ST(1) 机器码 D8 D1 FCOMI ST(0),ST(i) ST(0)-ST(1) 机器码 DB F0iii FCOMIP ST(0),ST(i) ST(0)-ST(1)并出栈机器码 DF F0iii FCOM real4 ptr mem ST(0)-实数mem 机器码D8 mm010mmm FCOM real8 ptr mem ST(0)-实数mem 机器码 DC mm010mmm FICOM word ptr mem ST(0)-整数mem 机器码 DE mm010mmm FICOM dword ptr mem ST(0)-整数mem 机器码 DA mm010mmm FICOMP word ptr mem ST(0)-整数mem并出栈机器码DE mm011mmmFICOMP dword ptr mem ST(0)-整数mem并出栈机器码DA mm011mmm FTST ST(0)-0 机器码 D9 E4 FUCOM ST(i) ST(0)-ST(i) 机器码DD E0iii FUCOMP ST(i) ST(0)-ST(i)并出栈机器码DD E1iii FUCOMPP ST(0)-ST(1)并二次出栈机器码 DA E9 FXAM ST(0)规格类型机器码 D9 E5 ---------- 四、运算指令 -------------------------------------------------------- FADD 把目的操作数(直接接在指令后的变量或堆栈缓存器) 与来源操作数(接在目的操作数后的变量或堆栈缓存器) 相加,并将结果存入目的操作数 FADDP ST(i),ST 这个指令是使目的操作数加上 ST 缓存器,并弹出 ST 缓存器,而目的操作数必须是堆栈缓存器的其中之一,最后不管目的操作数为何,经弹出一次后,目的操作数会变成上一个堆栈缓存器了 FIADD FIADD 是把 ST 加上来源操作数,然后再存入 ST 缓存器,来源操作数必须是字组整数或短整数形态的变数FSUB 减FSUBP FSUBR 减数与被减数互换FSUBRP FISUB FISUBR FMUL 乘FMULP FIMUL FDIV 除FDIVP FDIVR FDIVRP FIDIV FIDIVR FCHS 改变 ST 的正负值 FABS 把 ST 之值取出,取其绝对值后再存回去。
汇编语言的种类
汇编语言的种类汇编语言是计算机领域中的一门编程语言,它与机器语言密切相关,用于书写可以被计算机直接执行的程序代码。
汇编语言直接操作计算机底层硬件,因此在性能和效果上具有很大优势。
在汇编语言中,不同的体系结构和处理器都有不同的指令集和语法规则,这导致了汇编语言的种类繁多。
本文将介绍几种常见的汇编语言。
1. x86汇编语言x86汇编语言是最为广泛应用的汇编语言之一,在PC和服务器领域得到广泛使用。
x86指令集是英特尔和AMD等处理器厂商所采用的指令集架构,在x86汇编语言中,可以直接操作寄存器、内存以及其他外设,具有很高的灵活性和可操作性。
x86汇编语言使用Intel语法和AT&T语法两种不同的语法规则,常用的编译器有MASM、NASM和GAS。
2. ARM汇编语言ARM汇编语言广泛应用于移动设备、嵌入式系统和物联网等领域。
ARM处理器以其低功耗、高性能和内容丰富的架构而闻名,ARM汇编语言可以直接操作处理器寄存器、存储器和外设,具有很好的可移植性和可扩展性。
ARM汇编语言使用ARM体系结构定义的指令集和语法规则,常用的编译器有ARM汇编器和GNU汇编器等。
3. MIPS汇编语言MIPS汇编语言被广泛应用在嵌入式系统、数字信号处理以及网络设备等领域。
MIPS处理器以其简洁的指令集和高效的架构而著称,MIPS汇编语言可以直接控制寄存器、存储器以及其他外设,具有很高的执行效率和指令流水线能力。
MIPS汇编语言使用MIPS体系结构定义的指令集和语法规则,常用的编译器有MIPS汇编器。
4. PowerPC汇编语言PowerPC汇编语言主要应用于IBM PowerPC架构的服务器、工作站以及游戏机等领域。
PowerPC处理器以其高性能和可扩展性而著称,PowerPC汇编语言可以直接操作处理器寄存器、存储器和外设,具有很好的可移植性和性能表现。
PowerPC汇编语言使用PowerPC指令集和语法规则,常见的编译器有PowerPC汇编器。
汇编语言种类
汇编语言种类
汇编语言是一种极为底层的编程语言,其主要功能是将人类易于理解的高级语言转换成机器可执行的低级语言。
随着计算机技术的不断发展,汇编语言的应用范围也越来越广泛。
目前,主要有以下几种汇编语言:
1. x86汇编语言
x86汇编语言是目前应用最广泛的汇编语言之一,特别是在个人电脑和服务器上。
它最早出现在英特尔的16位处理器上,目前已经发展成为可以支持64位处理器的一种汇编语言。
x86汇编语言的使用范围非常广泛,例如操作系统、编译器等大型软件中都会大量使用。
2. ARM汇编语言
ARM汇编语言是一种轻量级、低功耗的汇编语言,它主要应用于嵌入式系统、移动设备、消费类电子产品等领域。
相比x86汇编语言,ARM汇编语言的代码更加紧凑,执行效率更高。
3. MIPS汇编语言
MIPS汇编语言是一种32位RISC(精简指令集计算机)体系结构的汇编语言,主要用于嵌入式系统、网络设备、数字视频等领域。
其指令集极为精简,执行效率较高且可定制性强。
4. AVR汇编语言
AVR汇编语言是一种基于8位微处理器的汇编语言,主要用于嵌入式系统、数字信号处理等领域。
AVR汇编语言的代码具有很强的可读性和易于调试的特点。
总之,汇编语言虽然种类不同,但其基本原理和操作方式都十分
相似,学习一种汇编语言后再学习其他汇编语言就会相对容易了许多。
同时,在实际开发中,也需要根据具体应用场景选择最适合的汇编语言,以获得更好的性能和效率。
汇编语言和指令集的关系
汇编语言和指令集是计算机编程中的两个关键概念,它们之间的关系密切,对于理解计算机系统的工作原理和编写高效的程序至关重要。
汇编语言是一种低级语言,它直接与计算机硬件交互。
汇编语言基于机器语言,机器语言是计算机可以理解的低级语言,它是用二进制代码编写的。
汇编语言将机器语言的指令集中封装成更易于人类理解的格式。
例如,在x86架构的计算机中,汇编语言可能包含如“MOV AX, 1234”这样的指令,这条指令将数值1234存储在寄存器AX中。
指令集则是计算机硬件的一种特性,它是一组为特定任务设计的微小命令。
指令集定义了计算机可以执行的操作,以及这些操作如何进行。
不同的计算机架构有不同的指令集,这使得它们在执行相同的汇编语言程序时可能会有不同的性能。
指令集通常根据应用领域进行优化,例如,为了提高多媒体处理速度,计算机可能会包含专门用于这种处理的指令集。
汇编语言和指令集的关系在于,汇编语言使用指令集来控制计算机执行任务。
在汇编语言程序中,程序员指定要执行的操作,这些操作由指令集中的特定指令实现。
指令集定义了这些操作如何执行,以及它们何时执行。
因此,理解指令集对于编写汇编语言程序至关重要。
总的来说,汇编语言和指令集之间的关系是:汇编语言是人与计算机硬件之间的接口,它使用指令集中定义的指令来控制计算机执行任务。
指令集定义了这些指令如何执行,以及它们在计算机中如何工作。
理解这两个概念对于理解计算机系统的工作原理和编写高效的程序至关重要。
x86架构汇编指令
x86架构汇编指令x86架构汇编指令是一种底层的机器语言指令集,用于在x86架构的计算机上执行任务。
它包含了一系列指令,用于操作寄存器、内存和其他硬件设备,以及进行算术和逻辑运算等操作。
本文将介绍几个常用的x86架构汇编指令,包括MOV、ADD、SUB和JMP。
1. MOV指令:MOV指令用于将数据从一个位置复制到另一个位置。
它的语法如下:MOV destination, source其中destination可以是一个寄存器或内存地址,source可以是一个寄存器、内存地址或立即数。
例如,MOV AX, BX将BX寄存器的值复制到AX寄存器中。
2. ADD指令:ADD指令用于将两个数相加,并将结果存储在目标位置。
它的语法如下:ADD destination, source其中destination可以是一个寄存器或内存地址,source可以是一个寄存器、内存地址或立即数。
例如,ADD AX, BX将AX寄存器的值与BX寄存器的值相加,并将结果存储在AX寄存器中。
3. SUB指令:SUB指令用于将两个数相减,并将结果存储在目标位置。
它的语法如下:SUB destination, source其中destination可以是一个寄存器或内存地址,source可以是一个寄存器、内存地址或立即数。
例如,SUB AX, BX将AX寄存器的值减去BX寄存器的值,并将结果存储在AX寄存器中。
4. JMP指令:JMP指令用于无条件地跳转到指定的地址。
它的语法如下:JMP destination其中destination可以是一个标签或地址。
例如,JMP LOOP将跳转到LOOP标签所在的位置。
除了上述指令外,x86架构汇编还包括许多其他指令,如CMP、AND、OR、NOT、XOR等,用于进行比较、逻辑运算和位操作等。
这些指令可以组合使用,以实现复杂的功能。
x86架构汇编指令的编写需要遵循一定的规范和语法。
每条指令都由一个助记符和操作数组成,它们之间用逗号隔开。
x86 str汇编指令
x86 str汇编指令
x86汇编指令中的str指令用于将数据从内存移动到寄存器中。
在x86架构中,mov指令可以实现相同的功能,但str指令具有一些优势。
首先,str指令遵循ARM汇编语义,即“加载/存储”(Load/Store)操作。
在ARM架构中,数据从内存到CPU之间的移动必须通过ldr/str 指令完成。
这与x86架构有所不同,x86架构中的mov指令可以在寄存器之间移动数据,或者将立即数移动到寄存器中。
其次,str指令在移动数据时具有更高的灵活性。
例如,str指令可以加载内存中的一个字节、字或双字数据到寄存器中,而mov指令只能移动一个字节或字。
此外,str指令还可以加载内存中的相对地址,这在某些场景下非常有用。
然而,需要注意的是,x86架构中并没有真正的ldr指令。
在x86汇编中,mov指令可以实现类似的功能,将从内存中某个地址的数据移动到寄存器中。
而str指令在x86架构中主要用作存储器到寄存器的数据传送。
总之,x86汇编指令中的str指令用于将数据从内存移动到寄存器,与mov指令具有相似的功能,但str指令在某些方面更具优势,例如
加载内存中的相对地址。
然而,需要注意的是,x86架构中并没有真正的ldr指令,而是使用mov指令来实现类似的功能。
x86汇编sub指令
x86汇编sub指令x86汇编中的sub指令用于执行减法操作。
它的基本语法如下:sub destination, source其中,destination是目标操作数,而source是源操作数。
sub指令的功能是将源操作数的值减去目标操作数的值,并将结果存储到目标操作数中。
在使用sub指令时,需要注意以下几点:1. 操作数的大小:- 如果目标操作数和源操作数都是字节大小的变量,那么执行sub指令时,将会进行无符号字节级别的减法运算。
- 如果目标操作数和源操作数都是字大小的变量,那么执行sub指令时,将会进行无符号字级别的减法运算。
- 如果目标操作数和源操作数都是双字大小的变量,那么执行sub指令时,将会进行无符号双字级别的减法运算。
2. 符号位的处理:- 当执行sub指令时,会根据运算结果设置CF(Carry Flag)标志和OF(Overflow Flag)标志。
如果结果小于0,则CF标志会被设置为1,否则为0。
如果结果溢出,则OF标志会被设置为1,否则为0。
接下来,我将为你提供两个示例来说明sub指令的使用。
示例1:字节级别的减法运算```asmsection .datavar1 db 10 ; 目标操作数var2 db 5 ; 源操作数section .textglobal _start_start:mov al, [var1] ; 将目标操作数加载到AL寄存器中sub al, [var2] ; 将源操作数从AL寄存器中减去mov [var1], al ; 将结果存储到目标操作数中; 可以在这里读取目标操作数的值,然后进行打印等操作; 退出程序mov eax, 1xor ebx, ebxint 0x80```示例2:双字级别的减法运算```asmsection .datavar1 dd 100 ; 目标操作数var2 dd 50 ; 源操作数section .textglobal _start_start:mov eax, [var1] ; 将目标操作数加载到EAX寄存器中sub eax, [var2] ; 将源操作数从EAX寄存器中减去mov [var1], eax ; 将结果存储到目标操作数中; 可以在这里读取目标操作数的值,然后进行打印等操作; 退出程序mov eax, 1xor ebx, ebxint 0x80```这两个示例展示了如何使用sub指令进行减法运算,并将结果存储在目标操作数中。
简明X86汇编语言教程
简明X86汇编语言教程在计算机科学领域中,汇编语言是一种低级语言,用于编写和控制计算机硬件操作的程序。
X86汇编语言是一种广泛应用于个人电脑和服务器系统的指令集体系结构。
本教程将简明地介绍X86汇编语言的基本概念、语法和指令集,以帮助初学者入门。
下面将按照教程的逻辑顺序,逐步介绍相关内容。
1. 汇编语言简介汇编语言是机器语言的简化形式,通过使用助记符,可以更便于人们理解和编写程序。
我们将会一起了解如何使用X86汇编语言进行编程,包括数据类型、寄存器的使用和基本指令的命令格式等。
2. 数据传送和运算在这一部分,我们将会学习如何在寄存器中存储和传送数据,以及如何进行基本的算术和逻辑运算。
我们还将介绍一些常用的指令,例如mov、add、sub等。
3. 程序控制结构我们将介绍如何使用条件语句(如if-else和循环语句),以及如何使用标志寄存器来判断程序的执行流程。
同时,我们还将学习如何调用和返回函数。
4. 存储器管理在这个部分,我们将了解如何在程序中使用存储器。
我们将学习如何声明和定义变量、数组和常量,以及如何使用栈来管理函数的调用和返回。
5. 输入和输出我们将会学习如何从键盘读取输入,以及如何将数据输出到屏幕上。
通过学习这些知识,我们可以编写更加实用的程序,与用户进行交互。
6. 异常处理在这一部分,我们将介绍如何处理程序中的异常和错误。
我们将学习如何使用中断来响应外部事件,并进行相应的处理。
我们还将了解如何调试程序,以及如何优化程序的性能。
通过学习本教程,您将掌握X86汇编语言的基本知识和技巧,能够编写简单的汇编程序并进行调试和优化。
希望这个教程对您学习和理解汇编语言有所帮助。
总结本教程简明地介绍了X86汇编语言的基本概念、语法和指令集。
通过系统地学习和实践,您将逐渐掌握汇编语言的编程技巧,并能够编写出高效、可靠的汇编程序。
汇编语言虽然相对较低级,但在某些场景下仍然非常重要,因此掌握汇编语言将为您成为一名更全面的程序员打下稳固的基础。
x86汇编 讲解
x86汇编讲解摘要:1.x86 汇编简介2.x86 汇编的基本语法3.x86 汇编的寄存器和内存4.x86 汇编的指令集5.x86 汇编的应用场景正文:【x86 汇编简介】x86 汇编是一种用于编写计算机程序的低级编程语言。
它是x86 架构处理器的指令集体系结构(ISA) 的助记符表示形式。
x86 汇编语言可以用于编写操作系统、驱动程序和嵌入式系统等底层应用程序。
由于其底层特性,x86 汇编语言能够直接访问计算机硬件,并实现高性能的计算。
【x86 汇编的基本语法】x86 汇编语言的基本语法包括以下几个部分:1.指令:x86 汇编指令是用于完成特定任务的命令。
每个指令都有一个操作码,它表示指令要执行的操作。
操作码后面通常跟有一些操作数,用于指定操作的对象。
2.寄存器:x86 汇编中的寄存器是一组高速存储单元,用于存储数据和地址。
常用的寄存器包括通用寄存器(EAX、EBX、ECX、EDX)、指针寄存器(ESP、EBP)和索引寄存器(ESI、EDI)等。
3.内存:x86 汇编中的内存是指计算机中的主存储器,用于存储程序和数据。
内存地址通常用基址(Base Address)加偏移量(Displacement)的方式表示。
4.常用指令:x86 汇编中有很多常用指令,包括数据传输指令(如MOV)、算术指令(如ADD、SUB)、逻辑指令(如AND、OR)、跳转指令(如JMP、JZ、JNZ)等。
【x86 汇编的寄存器和内存】x86 汇编中的寄存器和内存扮演着非常重要的角色。
它们可以存储程序中的数据和地址,并在程序运行过程中进行高速读写。
以下是一些常用的寄存器和内存操作指令:1.寄存器指令:MOV 寄存器,数值将数值移动到指定的寄存器中。
2.内存指令:MOV 内存地址,寄存器将寄存器的值移动到指定的内存地址。
3.加载/存储指令:LOAD/STORE 寄存器,内存地址在内存和寄存器之间传输数据。
【x86 汇编的指令集】x86 汇编指令集非常丰富,可以完成各种复杂的操作。
WindowsX8664位汇编语言入门
WindowsX8664位汇编语言入门Windows x86-64位汇编语言入门汇编语言是计算机硬件和操作系统之间的桥梁,它能够直接控制计算机的底层硬件。
对于计算机科学的学习者来说,了解汇编语言是非常重要的一步。
本文将介绍如何入门并学习Windows x86-64位汇编语言。
一、了解汇编语言的基本概念在开始学习汇编语言之前,我们需要先了解一些基本概念。
汇编语言是一种低级语言,它使用助记符来代替机器指令,这样更方便我们理解和编写程序。
汇编语言的基本单位是指令,每条指令对应着一条机器指令。
在x86-64架构中,指令长度可以是1到15个字节。
二、安装并配置开发环境要开始编写和执行汇编语言程序,我们首先需要安装一个好的开发环境。
在Windows操作系统上,常用的开发环境有MASM、NASM、TASM等。
这些开发工具可以帮助我们将汇编代码转换为可执行文件。
三、学习汇编语言的语法和指令集汇编语言与其他高级编程语言相比,语法更加简单和直接。
学习汇编语言的关键就是理解和掌握其语法和指令集。
在学习过程中,我们可以参考官方文档或者一些经典的教程,如《汇编语言程序设计》。
四、编写你的第一个汇编程序现在,我们可以尝试编写自己的第一个汇编程序。
我们可以从一个简单的程序开始,比如输出一个简单的“Hello, World!”。
下面是示例代码:section .datamsg db 'Hello, World!', 0section .textglobal _start_start:; 输出字符串mov eax, 4mov ebx, 1mov ecx, msgmov edx, 13int 0x80; 退出程序mov eax, 1xor ebx, ebxint 0x80这个程序使用Linux系统调用来输出字符串,并退出程序。
我们可以使用汇编器将其编译成可执行文件,然后在命令行中运行。
五、深入学习汇编语言的高级特性一旦掌握了汇编语言的基础知识,我们就可以进一步学习一些高级特性,如函数调用、内存管理、寄存器的使用等。
uxtw 汇编指令 -回复
uxtw 汇编指令-回复【uxtw汇编指令】是一种用于英特尔x86微处理器的汇编语言指令集。
在本篇文章中,我将为您详细介绍uxtw指令的相关内容,并逐步回答与该指令相关的问题。
一、什么是uxtw指令?uxtw指令是uxtw(Extended Zeros in Upper Half Words)的缩写,它是一条汇编指令,用于将指定源操作数零扩展到目的操作数中的上半字(高16位),同时保持目的操作数的下半字(低16位)不变。
此指令适用于16位操作数。
二、uxtw指令的语法:uxtw 目的操作数,源操作数三、uxtw指令的功能:该指令将源操作数的值零扩展到目的操作数的上半字,即将源操作数的最高位复制到目的操作数的高16位,而低16位保持不变。
四、使用uxtw指令的示例说明:假设有以下汇编代码段:mov ax, 0FF00huxtw ecx, ax在上述示例中,将0FF00h的值传送到ax寄存器中。
然后,使用uxtw指令将ax的值进行零扩展,并将结果传送到ecx寄存器中。
五、uxtw指令的相关问题解答:1. uxtw指令能在哪些寄存器之间进行操作?uxtw指令可以在通用寄存器之间进行操作,例如eax、ecx、edx等。
2. uxtw指令适用于16位操作数还是32位操作数?uxtw指令适用于16位操作数。
3. uxtw指令如何处理源操作数的符号位?uxtw指令会将源操作数的最高位复制到目的操作数的高16位,也就是说,它会考虑源操作数的符号位。
4. uxtw指令在何种情况下常用?uxtw指令通常用于零扩展有符号数,将其转换为无符号数。
5. 除了uxtw指令,还有其他指令可以进行零扩展操作吗?是的,在x86指令集中,还有类似的指令,如movzx和cbtw。
这些指令也可以实现零扩展的功能。
六、总结:本文详细介绍了uxtw指令的相关内容,并逐步回答了与该指令相关的问题。
uxtw指令是用于英特尔x86微处理器的汇编指令集中的一条指令,它可以将指定源操作数的值零扩展到目的操作数的上半字,并保持目的操作数的下半字不变。
汇编语言-指令集
例:假设(SS) = 2250H , (SP) = 0140H 如果在堆栈中存入5个数据,则栈顶的物理地址是多少? 未存入数据之前物理地址=22500 + 0140=22640H 存入5个数据,栈顶的物理地址为: 22640 – 0A = 22636H
如果又从堆栈中取出3个数据,则栈顶的物理地址是多少? 22636 + 6 = 2263CH
80x86/8088指令系统 8086/8088的指令系统丰富,而且指令的功能也强。 大多数指令既能处理字数据,又能处理字节数据。 指令系统可分为如下6个功能组: (1)数据传送 (2)算术运算 (3)逻辑运算 (4)串操作 (5)程序控制 (6)处理器控制 汇编语言中,指令语句可由四部分组成,一般格式如下: [标号:] 指令助记符 [操作数1 [,操作数2]] [;注释]
例如:PUSH AX 假设(AX) = 2107H
(2)出栈指令POP 格式: POP DST 执行的操作:从堆栈顶弹出一个字数据到目的操作数DST。 步骤为: 1. 把堆栈指针寄存器SP所指的字数据送往目的操作数DST; 2. 堆栈指针寄存器器SP的值加2。 DST可以是通用寄存器、段寄存器(CS除外),也可以是字 存储单元
3.加1指令INC(INCrement) 其格式如下:INC OPRD (OPRD) <- (OPRD) + 1 功能:对操作数加1. OPRD可以是通用寄存器,也可以是存储单元。 指令执行的结果影响ZF、SF、OF、PF、AF, 但不影响CF. 改指令主要用于调整地址指针和用于计算器。
例:写出把首地址为BLOCK的字数组的第6个字送到DX寄存 器的指令。 (1)使用寄存器间接寻址 MOV BX , OFFSET BLOCK ADD BX , 000AH MOV DX , [BX] (2)寄存器相对寻址 MOV BX , OFFSET BLOCK MOV DX , [BX + 000AH]
x86汇编 语法
x86汇编语法
x86汇编语言是一种低级语言,用于编写在x86架构上运行的程序的机器代码。
它使用助记符表示指令,这些助记符通常与对应的机器代码指令相对应。
以下是一些x86汇编语言的语法要点:
1. 指令格式:x86汇编语言中的指令通常由操作码和操作数组成。
操作码指定要执行的操作,而操作数指定要操作的数据或寄存器。
例如,MOV指令将一个值从一个位置移动到另一个位置,其格式为“MOV destination, source”。
2. 寄存器:x86架构包含多个寄存器,用于存储数据和地址。
在汇编语言中,可以使用寄存器名来引用寄存器中的值。
例如,EAX寄存器可以表示为“EAX”。
3. 立即数:立即数是直接包含在指令中的数字值。
例如,MOV AX, 1000H指令将1000H(十进制为4096)移动到AX寄存器中。
4. 内存操作数:当需要从内存中读取或写入数据时,可以在指令中使用内存操作数。
内存操作数由一个基址和一个变址量组成,它们可以是寄存器或立即数。
例如,MOV AX, [BX+SI]指令将BX和SI寄存器的值相加,并将结果作为基址,从该基址处读取一个字(16位)到AX寄存器中。
5. 标志寄存器:x86架构包含一个标志寄存器,用于存储各种状态标志。
这些标志用于指示算术操作的结果、零标志、符号标志等。
在汇编语言中,可以使
用条件码指令来测试标志寄存器的值。
以上是x86汇编语言的一些基本语法要点。
学习x86汇编语言需要熟悉指令集、寄存器、内存操作数、标志寄存器等概念,并能够编写简单的程序来执行基本操作。
x86 汇编判断指令
x86 汇编判断指令摘要:一、x86 汇编简介二、判断指令概述三、比较指令1.通用比较指令2.专用比较指令四、逻辑指令1.AND 指令2.OR 指令3.XOR 指令4.NOT 指令五、移位指令1.循环移位指令2.方向控制移位指令六、测试指令1.测试指令概述2.常见测试指令七、总结正文:x86 汇编是一种基于英特尔x86 架构的计算机编程语言。
在x86 汇编中,判断指令被广泛应用于条件跳转、条件执行等场景。
本文将详细介绍x86 汇编中的判断指令。
判断指令主要分为比较指令、逻辑指令、移位指令和测试指令四类。
首先,比较指令用于比较两个操作数的值。
通用比较指令有CMP(比较)、TEST(测试)等。
专用比较指令有CMPXCHG(比较交换)、MOVSX (移动到零扩展)等。
其次,逻辑指令用于对操作数执行逻辑运算。
常见的逻辑指令有AND (逻辑与)、OR(逻辑或)、XOR(逻辑异或)和NOT(逻辑非)。
再者,移位指令用于将操作数的二进制位进行移位操作。
循环移位指令有ROL(循环左移)、ROR(循环右移)等。
方向控制移位指令有SHL(逻辑左移)、SHR(逻辑右移)等。
最后,测试指令用于测试操作数的特定位是否为1。
常见的测试指令有JC(无符号大于)、JE(无符号等于)、JG(无符号大于等于)、JL(无符号小于)、JN(无符号不等于)等。
总之,x86 汇编中的判断指令在编程过程中起着关键作用,通过灵活运用各种判断指令,可以实现条件跳转、条件执行等多种功能。
x86汇编指令整理
x86汇编指令整理1,寻址⽅式1,⽴即数寻址MOV AX, 0102H ;AX←0102H2、寄存器寻址⽅式指令中指明某个寄存器其内容即为操作数,寄存器在CPU内,不⽤总线周期,执⾏速度快。
8位寄存器r8:AH、AL、BH、BL、CH、CL、DH、DL16位寄存器r16:AX、BX、CX、DX、SI、DI、BP、SP4个段寄存器seg:CS、DS、SS、ESMOV AX, BX ;AX←BX3,直接寻址⽅式指令中直接给出操作数所在内存单元的有效地址(EA即偏移地址)默认的段地址在DS段寄存器,若在其它段可使⽤段超越前缀改变。
⽤⽅括号包含有效地址,表达存储单元的内容直接地址也可⽤标号代表,⽅括号可省略。
MOV AX, [2000H] ;AX←DS:[2000H]MOV AX, ES: [2000H] ;AX←ES:[2000H]4、寄存器间接寻址⽅式指令中给出的寄存器的内容包含操作数的有效地址。
间接寻址中使⽤的寄存器名要⽤⽅括号括起来1、基址寻址⽤BX或BP作间接寻址寄存器如:MOV AX,[BX] ;隐含在DS段MOV AX,[BP] ;隐含在SS段2、变址寻址⽤SI或DI作间接寻址寄存器如:MOV CL, [SI]MOV AX, [DI]单独使⽤SI或DI时,隐含在DS段中在串操作时,SI隐含在DS段中,DI隐含在ES段中。
3、相对基址寻址指令中给出基址寄存器及位移量,⼆者之和为操作数的有效地址。
位移量可以是8位或16位。
有效地址=BX/BP+8/16位位移量4、相对变址寻址指令中给出变址寄存器及位移量,⼆者之和为操作数的有效地址。
有效地址=SI/DI+8/16位位移量段地址对应BX/SI/DI寄存器默认是DS,对应BP寄存器默认是SS;可⽤段超越前缀改变MOV AX, [SI+06H] ;AX←DS:[SI+06H]MOV AX, 06H[SI] ;AX←DS:[SI+06H]5、基址变址寻址⽅式有效地址由基址寄存器(BX或BP)的内容加上变址寄存器(SI或DI)的内容构成:有效地址=BX/BP+SI/DI段地址对应BX基址寄存器默认是DS,对应BP基址寄存器默认是SS;可⽤段超越前缀改变 MOV AX, [BX+SI] ;AX←DS:[BX+SI]MOV AX, [BX][SI] ;AX←DS:[BX+SI]6、相对基址变址寻址⽅式有效地址是基址寄存器(BX/BP)、变址寄存器(SI/DI)与⼀个8位或16位位移量之和:有效地址=BX/BP+SI/DI+8/16位位移量段地址对应BX基址寄存器默认是DS,对应BP基址寄存器默认是SS;可⽤段超越前缀改变 MOV AX, [BX+DI+6] ;AX←DS:[BX+DI+6]MOV AX, 6[BX+DI] MOV AX, 6[BX][DI]各种寻址⽅式综合举例设BX=1200H DI=10A0H 位移量=2BC0HDS=2400H 求各种寻址⽅式下的有效地址和物理地址。
80X86常用汇编指令集
80X86常用汇编指令集ZZ作者 : 赵振东ZZD学习汇编语言,最关键的就在于汇编指令集的掌握以及计算机工作方式的理解,以下是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。
七、32位CPU新增指令(后续补充并完善)除上述的一些指令外,还有许多32位80X86CPU新增指令,这些指令有时会简化程序设计,不过由于我也是刚刚学习汇编,这些都是从书上看到的,所以很多还不是十分了解,我写这些的目的仅仅是想让自己能更好的去记住这些指令的作用和用法,同事也希望和我一样刚入门的朋友能够多了解一些,并没有其他目的,所有的示例也并没有经过实际的代码测试,所以希望各位朋友,不管你喜欢不喜欢,反对不反对,请文明发言,谢谢!------------------------------------------------数据传送指令开始-------------------------------------------------------1、MOV(传送)指令写法:MOV target,source功能描述:将源操作数source的值复制到target中去,source值不变注意事项:1)target不能是CS(代码段寄存器),我的理解是代码段不可写,只可读,所以相应这地方也不能对CS执行复制操作。
x86汇编 讲解
x86汇编讲解摘要:1.汇编语言简介2.x86汇编语言的特点3.x86汇编语言的基本语法4.x86汇编语言的寻址方式5.x86汇编语言的指令集6.x86汇编语言的程序结构7.x86汇编语言的应用领域正文:汇编语言是一种低级编程语言,它用助记符代替机器码操作指令。
汇编语言与计算机硬件结构密切相关,因此不同计算机体系结构有着不同的汇编语言。
x86汇编语言就是针对英特尔x86架构设计的一种汇编语言。
x86汇编语言具有以下特点:1.寄存器繁多:x86汇编语言拥有多种寄存器,如通用寄存器、指针寄存器、索引寄存器等。
2.内存寻址:x86汇编语言使用段寄存器进行内存寻址,提供了多种寻址方式,如直接寻址、间接寻址、寄存器间接寻址等。
3.操作数:x86汇编语言支持多种操作数,如立即数、寄存器、内存单元等。
4.指令集丰富:x86汇编语言拥有丰富的指令集,可以完成各种操作,如数据传输、算术运算、逻辑运算、跳转等。
x86汇编语言的基本语法包括:1.指令:x86汇编语言的指令由操作码和操作数组成,如MOV AX, 10。
2.伪指令:x86汇编语言中的伪指令用于描述程序的结构,如ORG、END 等。
3.宏:x86汇编语言支持宏定义,可以将一段代码定义为一个宏,如宏MOV_MEMORY。
x86汇编语言的寻址方式包括:1.直接寻址(DA):直接访问内存单元。
2.间接寻址(IA):通过寄存器或内存单元间接访问内存单元。
3.寄存器间接寻址(RIA):直接使用寄存器中的值作为操作数。
4.寄存器相对寻址(RRA):使用寄存器与基址寄存器的差值作为操作数。
x86汇编语言的指令集包括:1.数据传输指令:如MOV、PUSH、POP等。
2.算术运算指令:如ADD、SUB、MUL、DIV等。
3.逻辑运算指令:如AND、OR、XOR、NOT等。
4.移位运算指令:如SHL、SHR、ROL、ROR等。
5.比较运算指令:如CMP等。
6.跳转指令:如JMP、JZ、JNZ等。
汇编语言x86汇编指令集大全
汇编语言x86汇编指令集大全汇编语言是计算机体系结构学科中的重要内容之一,它可以直接操作计算机硬件,实现对机器指令的精确控制。
而x86汇编则是汇编语言中最常用的一种,它广泛应用于各类个人电脑和服务器等计算设备中。
x86汇编指令集是汇编语言中的核心,掌握其基本指令对于开发高效的汇编程序至关重要。
本文将介绍x86汇编指令集的各个方面,包括数据传输指令、算术运算指令、逻辑运算指令、分支控制指令以及其他常用指令等内容,以帮助读者全面理解和掌握x86汇编语言。
一、数据传输指令数据传输指令是汇编语言中最基本的指令之一,用于实现数据在寄存器、内存和I/O端口之间的传递。
常见的数据传输指令包括MOV、XCHG、PUSH和POP等。
MOV指令用于将数据从一个位置传送到另一个位置,可以将数据从内存中传送到寄存器,也可以将数据从寄存器传送到内存。
例如,MOV AX, BX表示将寄存器BX中的数据传送到寄存器AX中。
XCHG指令用于交换两个操作数的值,例如,XCHG AX, BX表示交换寄存器AX和BX中的数据。
PUSH指令将数据推入堆栈,POP指令从堆栈中弹出数据。
这两个指令常用于函数调用和局部变量的保存与恢复。
二、算术运算指令算术运算指令用于执行各种数值计算操作,包括加法、减法、乘法、除法以及取模等。
常见的算术运算指令包括ADD、SUB、MUL、DIV和IMUL等。
ADD指令用于进行加法运算,可以将两个操作数相加,并将结果保存在目标操作数中。
例如,ADD AX, BX表示将寄存器BX中的值加到寄存器AX中。
SUB指令用于进行减法运算,可以将目标操作数减去源操作数,并将结果保存在目标操作数中。
MUL指令用于进行无符号数的乘法运算,可以将一个操作数与寄存器中的值相乘,并将结果保存在一对寄存器中。
DIV指令用于进行无符号数的除法运算,可以将寄存器中的值除以一个操作数,并将商保存在一个寄存器中,余数保存在另一个寄存器中。
IMUL指令用于进行有符号数的乘法运算,功能与MUL指令类似,但结果为有符号数。
- 1、下载文档前请自行甄别文档内容的完整性,平台不提供额外的编辑、内容补充、找答案等附加服务。
- 2、"仅部分预览"的文档,不可在线预览部分如存在完整性等问题,可反馈申请退款(可完整预览的文档不适用该条件!)。
- 3、如文档侵犯您的权益,请联系客服反馈,我们会尽快为您处理(人工客服工作时间:9:00-18:30)。
语法: 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: 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) 地址
2)算术指令:用来执行算术运算。
算术指令类型 指 令 说 明
加法指令 ADD(加法)、ADC(带进位加法)、INC(加1)
减法指令 SUB(减法)、SBB(带借位减法)、DEC(减1)、NEG(求补)、CMP(比较)
乘法指令 MUL(无符号数乘法)、IMUL(带符号数乘法)
语法: SCASB SCASW
标志位: C,P,Z,S,O
LODSB,LODSW,STOSB,STOSW
功能: 字符串载入或存贮指令
语法: LODSB LODSW STOSB STOSW
标志位: 无
REP,REPE,REPNE
功能: 重复前缀指令集
语法: REP 指令S REPE 指令S REPNE 指令S
子程序指令 CALL(调用指令)、RET(返回指令)
中断指令 INT(中断)、INTO(如溢出则中断)、RIET(从中断返回)
除法指令 DIV(无符号数除法)、IDIV(带符号数除法)、CBW(字节转换为字)、CWD(字转换为双字)
3)逻辑指令:对字或字节执行逻辑运算。
逻辑指令类型 指 令 说 明
逻辑运算指令 AND(逻辑与)、OR(逻辑或)、NOT(逻辑非)、XOR(异或)、TEST(测试)
移动指令 SHL(逻辑左移)、SAL(算术左移)、SHR(逻辑右移)、SAR(算术右移)、ROL(循环左移)、ROR(循环右移)、RCL(带进位循环左移)、RCR(带进位右移)
4)串处理指令:处理存放存储器里的数据串。
串处理指令类型 指 令 说 明
指 令 MOVS(串传送)、CMPS(串比较)、SCAS(串扫描)、LODS(从串取)、STOS(存入串)
5)控制转移指令:用来控制程序的执行流程。
控制转移指令类型 指 令 说 明
功能: 非压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
字符串操作指令集
MOVSB,MOVSW,MOVSD
功能: 字符串传送指令
语法: MOVSB MOVSW MOVSD
标志位: 无
CMPSB,CMPSW,CMPSD
功能: 字符串比较指令
语法: CMPSB CMPSW CMPSD
标志位: C,P,Z,S,O
SCASB,SCASW
功能: 字符串搜索指令
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
CMP
功能: 比较OP1与OP2的值
语法: CMP r/m,r/m/data
标志位: C,P,A,Z,O
JMP
功能: 跳往指定地址执行
语法: JMP 地址
JXX
功能: 当特定条件成立则跳往指定地址执行
0时成立
B: BELOW,当C=1时成立
标志位: 无
CALL,RET
功能: 子程序调用,返回指令
语法: CALL 地址 RET RET n
标志位: 无
INT,IRET
功能: 中断调用及返回指令
语法: INT n IRET
标志位: 在执行INT时,CPU会自动将标志寄存器的值入栈,在执行IRET时则会将堆栈中的标志值弹回寄存器
数据传送指令类型 指 令 说 明
通用数据传送指令 MOV(传送)、PUSH(进栈)、POP(出栈)、XCHG(交换)
累加器专用传送指令 IN(输入指令) 、OUT(输入指令)
地址传送指令 LEA(有效地址送寄存器)、LDS(指针送寄存器和DS)、LES(指针送寄存器和ES)
标志寄存器传送指令 LAHF(标志送AH)、SAHF(AH送标志寄存器)、PUSHF(标志进栈)、POPF(标志出栈)
格式: 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
影响标志: C,P,Z,S,O
程序流程控制指令集
CLC,STC,CMC
功能: 设定进位标志
语法: CLC STC CMC
标志位: C
CLD,STD
功能: 设定方向标志
语法: CLD STD
标志位: D
CLI,STI
功能: 设定中断标志
语法: CLI STI
标志位: I
IBM-PC汇编语言指令集
数据传送指令集
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
影响标志: 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的值加一或减一
标志位: 依指令S而定
对于IBM PC机它有它的指令系统,其中包括:数据传送指令、串处理指令、算术指令、控制移动指令、逻辑指令、处理机控制指令。
这里将简单介绍其指令类型及指令说明,如有要求给具体的指令格式及应用,请与amay联系,amay加以更新。
1)数据传送指令:负责把数据、地址或立即数传送到寄存器或存储单元中。
无条件转移指令 JMP(段间和段内转移)
条件转移指令 JZ(结果为0(或相等)则转移)、JS(结果为负则转移)、JNS(结果为正则转移)、JO(溢出则转移)、JNO(不溢出则转移)、JP(奇偶位为1则转移)、JNP(奇偶位为0则转移)
循环指令 LOOP(循环指令)、LOOPPZ/LOOPE(当为0或相等时循环指令)、LOOPNZ/LOOPNE(当不为0或不相等时循环指令)
功能: 执行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
语法: 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
功能: 移位指令
语法: SHR r/m,data/CL SHL r/m,data/CL SAR r/m,data/CL SAL r/m,data/CL
影响标志: C,P,Z,S,O
ROR,ROL,RCR,RCL
功能: 循环移位指令
语法: ROR r/m,data/CL ROL r/m,data/CL RCR r/m,data/CL RCL r/m,data/CL