(完整版),汇编语言速成秘籍,推荐文档

合集下载

(完整word版)汇编语言指令集合-吐血整理,推荐文档

(完整word版)汇编语言指令集合-吐血整理,推荐文档

8086/8088指令系统记忆表数据寄存器分为: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):附加段寄存器。

完整word版,汇编指令,推荐文档

完整word版,汇编指令,推荐文档

完整word版,汇编指令,推荐文档一、数据传送指令: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、JC、JCXZ、LOOP、LOOPZ、LOOPNZ、LOOPNE、CALL、RET、INT。

五、串操作指令:MOVS、LODS、STOS、CMPS、SCAS。

六、标志处理指令:CLC、STC、CLD、STD。

一、数据传送1、MOV描述:赋值指令格式:MOV DST,SRC功能:DST <= SRC注意:①不能DST,SRC都是存储器,这也是所有双操作数指令的通用要求。

②但其中一个是段寄存器时,另一个操作数必须是数据寄存器。

③不允许往CS传递数据④将立即数送存储时,要指定操作数类型。

BYTE PTR ,WORD PTR, DWORD PTR⑤不影响PSW2、PUSH描述:入栈指令格式:PUSH SRC功能:将SRC入栈注意:①只能是对“字”操作。

3、POP描述:出栈指令格式:POP DST功能:将栈顶元素出栈赋值给DST4、XCHG描述:数据交换指令格式:SCHG DST,SRC功能:将DST.SRC的值进行交换注意:①不能DST,SRC都是存储器,这也是所有双操作数指令的通用要求。

5、IN格式:IN DST,SRC功能:从SRC端口读取一个字节/字到DST中。

6、OUT格式:OUT DST,SRC功能:将SRC中的数据送到DST短空中7、XLAT描述:取表指令格式:XLAT功能:以DS:[BX+AL]为地址提取一个字节的数据送到AL中8、LEA格式:LEA REG,MEM功能:取MEM的偏移地址送到REG中。

汇编语言速成指南

汇编语言速成指南

汇编语言速成指南
《汇编语言速成指南》
嘿,朋友们!今天咱就来聊聊汇编语言这个神奇的东西。

你们知道吗,我之前学汇编语言的时候,就跟走进了一个满是奇怪符号和指令的迷宫一样。

记得有一次,我坐在电脑前,面对着那一堆让人眼花缭乱的代码,脑袋都大了。

我就像个在迷雾中摸索的人,一会儿看看这个指令,一会儿瞅瞅那个符号,完全不知道从哪儿下手。

我开始一个一个地去理解那些指令的意思,就好像在破解一道道神秘的密码。

比如说那个“MOV”指令吧,我得搞清楚它到底是把什么数据移动到哪里去。

有时候我会记错,然后程序就运行得乱七八糟,我就忍不住嘟囔:“哎呀,这咋又错啦!”
然后还有那些寄存器啊,就像是一个个小小的宝库,我得知道怎么合理地利用它们来存放数据。

有一次我不小心把数据放错了寄存器,结果程序就完全不是我想要的样子了,我那个郁闷啊!
不过呢,随着我不断地学习和实践,我慢慢地找到了一些窍门。

我开始能熟练地运用各种指令,让程序按照我的想法来运行。

就好像我终于找到了迷宫的出口,那种感觉别提多棒啦!
学汇编语言啊,就像是一场冒险,虽然过程中会遇到很多困难和挑战,但当你最终掌握了它,那种成就感真的是无与伦比的。

所以啊,大家别害怕,勇敢地去探索这个神奇的汇编语言世界吧!相信你们也一定能在其中找到属于自己的乐趣和成就的哟!哈哈!
这就是我学习汇编语言的一点小经历,希望能给你们带来一些启发呀!加油吧!。

汇编语言入门指南

汇编语言入门指南

汇编语言入门指南在计算机科学领域中,汇编语言被认为是一门底层的编程语言。

尽管近年来高级编程语言的流行度逐渐上升,但了解汇编语言仍然是一项重要的技能。

本文将探讨汇编语言的基础知识,以及为什么学习汇编语言对于一个程序员来说是至关重要的。

1. 什么是汇编语言?在深入了解汇编语言之前,我们先来了解一下它是什么。

汇编语言是一种能够与计算机硬件直接交互的低级编程语言。

它是由一系列符号和指令组成的,这些指令可以告诉计算机执行特定的操作。

汇编语言相对于高级编程语言而言更接近计算机的底层,直接操作内存和寄存器。

因此,了解汇编语言对于理解计算机的工作原理非常重要。

2. 为什么要学习汇编语言?尽管高级编程语言用起来更加方便快捷,但学习汇编语言仍有许多好处。

首先,学习汇编语言可以帮助程序员更好地理解计算机的底层运行方式。

当我们使用高级编程语言编写代码时,我们往往不知道代码被编译成机器代码之后实际发生了什么。

而通过学习汇编语言,我们能够更加清楚地了解代码是如何被翻译成机器代码并在计算机上执行的。

其次,学习汇编语言可以提高对其他编程语言的理解能力。

尽管现代高级编程语言提供了许多高级的抽象概念和数据结构,但它们最终会被转化为汇编语言程序。

通过理解汇编语言,我们可以更好地理解高级编程语言在底层是如何运作的,这将使我们在编写代码时能够更加高效和优化。

最后,学习汇编语言可以使程序员具备更强大的调试能力。

当我们遇到复杂的Bug或性能问题时,理解汇编语言将使我们能够更深入地分析问题所在。

我们可以通过阅读和理解汇编代码来定位问题,并优化相关的程序部分。

3. 汇编语言的基础知识现在让我们来了解一些汇编语言的基础知识。

首先是汇编器,它是一种将汇编语言翻译成机器语言的工具。

汇编器将我们编写的汇编代码翻译成计算机硬件能够理解执行的指令。

每个处理器架构都有自己的汇编语言,因此我们需要根据特定的处理器来选择相应的汇编语言。

其次是汇编语言的语法。

汇编语言的语法通常包括指令操作码(Opcode)、标号(Label)、寄存器(Register)和操作数(Operand)等。

(完整word版)汇编语言指令详解大全,推荐文档

(完整word版)汇编语言指令详解大全,推荐文档
直接寻址位传送到进位位
2
1
MOV
bit, C
进位位位传送到直接寻址
2
2
JC
rel
如果进位位为1 则转移
2
2
JNC
rel
如果进位位为0 则移
2
2
JB
bit,rel
如果直接寻址位为1 则转移
3
2
JNB
bit,rel
如果直接寻址位为0 则转移
3
2
JBC
bit,rel
直接寻址位为1 则转移并清除该位
2
2
(伪指令)
1
1
RRC
A
带进位累加器循环右移
1
1
SWAP
A
累加器高、低4 位交换
1
1
(控制转移类指令)
JMP
@A+DPTR
相对DPTR 的无条件间接转移
1
2
JZ
rel
累加器为0 则转移
2
2
JNZ
rel
累加器为1 则转移
2
2
CJNE
A,direct,rel
比较直接地址和累加器,不相等转移
3
2
CJNE
A,#data,rel
1
2
MOVX
A,@Ri
外部RAM(8 地址)传送到累加器
1
2
MOVX
A,@DPTR
外部RAM(16 地址)传送到累加器
1
2
MOVX
@Ri,A
累加器传送到外部RAM(8 地址)
1
2
MOVX
@DPTR,A
累加器传送到外部RAM(16 地址)

汇编语言入门教程

汇编语言入门教程

汇编语言入门教程2007-04-29 22:04对初学者而言,汇编的许多命令太复杂,往往学习很长时间也写不出一个漂漂亮亮的程序,以致妨碍了我们学习汇编的兴趣,不少人就此放弃。

所以我个人看法学汇编,不一定要写程序,写程序确实不是汇编的强项,大家不妨玩玩DEBUG,有时CRACK 出一个小软件比完成一个程序更有成就感(就像学电脑先玩游戏一样)。

某些高深的指令事实上只对有经验的汇编程序员有用,对我们而言,太过高深了。

为了使学习汇编语言有个好的开始,你必须要先排除那些华丽复杂的命令,将注意力集中在最重要的几个指令上(CMP LOOP MOV JNZ……)。

但是想在啰里吧嗦的教科书中完成上述目标,谈何容易,所以本人整理了这篇超浓缩(用WINZIP、WINRAR…依次压迫,嘿嘿!)教程。

大言不惭的说,看通本文,你完全可以“不经意”间在前辈或是后生卖弄一下DEBUG,很有成就感的,试试看!那么――这个接下来呢?――Here we go!(阅读时看不懂不要紧,下文必有分解)因为汇编是通过CPU和内存跟硬件对话的,所以我们不得不先了解一下CPU和内存:(关于数的进制问题在此不提)CPU是可以执行电脑所有算术╱逻辑运算与基本I/O 控制功能的一块芯片。

一种汇编语言只能用于特定的CPU。

也就是说,不同的CPU其汇编语言的指令语法亦不相同。

个人电脑由1981年推出至今,其CPU发展过程为:8086→80286→80386→80486→PENTIUM →……,还有AMD、CYRIX等旁支。

后面兼容前面CPU的功能,只不过多了些指令(如多能奔腾的MMX指令集)、增大了寄存器(如386的32位EAX)、增多了寄存器(如486的FS)。

为确保汇编程序可以适用于各种机型,所以推荐使用8086汇编语言,其兼容性最佳。

本文所提均为8086汇编语言。

寄存器(Register)是CPU内部的元件,所以在寄存器之间的数据传送非常快。

用途:1.可将寄存器内的数据执行算术及逻辑运算。

(完整word版)汇编语言知识点总结(word文档良心出品)

(完整word版)汇编语言知识点总结(word文档良心出品)

汇编语言精简版版权归属GuYue.Wang一、入门基础1.汇编基本格式2.内存管理:小端存储。

3.寄存器16位CPU通用寄存器共8个:AX,BX,CX,DX,BP,SP,SI,DI,它们都可以作为普通的数据寄存器来使用,也有一些特殊的功能,如下:①数据寄存器AX:BX:存放偏移地址CX: 循环次数(loop)DX:②指针寄存器SI:存放偏移地址,指向源操作数或作为变址寄存器,参与基址、变址寻址DI:存放偏移地址,指向目的操作数或作为变址寄存器,参与基址、变址寻址SP:堆栈指针,存放偏移地址,与SS结合使用BP:基址寄存器,存放偏移地址,与DS结合使用IP: 指令指针③段寄存器CS:代码段DS:数据段SS:堆栈段ES:4.标志位①ZF(零标志位):结果为0,则ZF=1.②PF(奇偶标志位):结果所有bit位1的个数为偶数,PF=1③SF(符号标志位):有符号数运算,结果为负,SF=1④OF(溢出标志位):有符号数运算,发生溢出,OF=1⑤CF(进位标志位):无符号数运算,记录了最高有效位向更高位的进位或借位5.定义数据二、指令集1.数据传送指令1> MOV <目的操作数> , <源操作数>①两个操作数位数一致②不能在两个存储单元之中进行数据直接传送③不能在两个段寄存器之间进行数据直接传送④imm不能直接送入段寄存器⑤目的操作数不能是CS,IP2> XCHG <目的操作数> , <源操作数> :交换两个操作数的内容xchg reg , regxchg reg , memxchg mem , reg3>LEA <OP2> , <OP1> :将OP1的地址偏移量传送给OP2①源操作数必须是内存操作数②目的操作数必须是16位的通用寄存器4>PUSH <OP> , POP <OP>:堆栈①SS:栈段寄存器SP:栈顶指针(使用时应当先初始化)②一次压入或弹出一个字,栈顶最大变化范围0~FFFFH③执行PUSH、POP时,SP指针默认移动④栈空:SP指向栈空间最高地址单元的下一个单元⑤OP:段寄存器(除CS),16位通用寄存器,内存的16位字2.算数运算指令1> ADD <OP1> , <OP2> | SUB <目的> , <源>①目的=目的+/-源②两操作数不能同时为mem(注:ADD 、SUB影响标志位:CF、ZF、SF、OF、AF、PF)2> INC <reg/mem>:自增1 | DEC <reg/mem>:自减1(注:INC、DEC适用于无符号运算,不影响进位标志CF)3> NEG <reg/mem> :求负(求补),按位取反加1①影响标志位:CF、ZF、SF、OF、AF、PF4> CMP <> , <>:目的操作数—源操作数,不回送结果,只影响标志位①根据相减结果修改OF、SF、ZF、CF、AF、PF②无符号数的比较:③有符号数的比较:5> MUL <乘数>(无符号乘法)| IMUL <乘数>(有符号乘法)①乘数不能位imm②IMUL指令的执行结果的高半部分不是低半部分的符号扩展,则设置CF、OF6> DIV <除数>(无符号除法)| IDIV <除数>(有符号除法)①除数不能位imm②IDIV:余数符号与被除数相同3.逻辑运算与移位指令1>AND <目的> , <源>:按位相与,将结果保存在目的操作数中①总是清除OF 和CF,根据结果修改SF、ZF、PF②对特定位清‘0’同时保留其他位③应用:字符大小写转化2> OR <目的> , <源>:按位相或,将结果保存在目的操作数中①使CF=0、OF=0,根据结果修改SF、ZF、PF②对特定位置‘1’③将数字转化位对应的ASCII码3> NOT <reg/mem>:按位取反,不影响任何标志位4> XOR <目的> , <源>:按位异或,将结果保存在目的操作数中①对某些为取反,且不影响其它位,与‘0’异或保持不变;与‘1’异或取反②对寄存器清0,或判断两个值是否相等③交换两个数,不使用中间变量④CF=0,OF=0,PF、SF、ZF变5> TEST <OP> , <imm>:按位相与,不回送结果①清除OF、CF;修改SF、ZF、PF②测试某些位是‘0’或‘1’6> SHL、SHR①格式:SHL mem/reg , 1SHL mem/reg , CL(移动次数>1放入CL)②③相当于乘除法4.程序控制指令1> JMP :无条件转移指令2>LOOP:循环指令,循环次数存于cx中,执行loop时首先CX=CX-1,然后判断CX=0?,是则跳转3>条件跳转指令①基于特定的标志值②根据操作数之间是否相等,或根据(E)CX的值与CMP <left> , <right>指令结合使用③基于无符号整数比较结果的跳转指令④基于有符号整数比较结果的跳转指令5.输入输出指令(接口与CPU之间的操作)1> IN AL|AX , <接口地址> :从接口到CPU的输入操作2> OUT <接口地址> , AL|AX :从CPU到接口的输出操作①CPU只能用AL或AX接收或发送数据②直接寻址(接口地址用一个字节表示00~FFH)IN AL, 35HOUT 44H , AX③寄存器间接寻址(接口地址由DX内容决定0000~FFFFH)MOV DX,03F8HIN AL ,DX三、补充1.CLC :使CF=02.ADC <op1> , <op2> :op1=op1+op2+CF。

(完整版)C51单片机汇编语言指令集,推荐文档

(完整版)C51单片机汇编语言指令集,推荐文档

的逻辑判断,结果存回累加器
ANL 1 1 将累加器的值与间接地址的内容做AND
A,@Ri
的逻辑判断,结果存回累加器
ANL 2 1 将累加器的值与常数做AND的逻辑判断,
A,#data
结果存回累加器
ANL 2 1 将直接地址的内容与累加器的值做AND
direct,A
的逻辑判断,结果存回该直接地址
ANL
1 1 将累加器的值减去寄存器的值减借 位C,结果存回累加器
2 1 将累加器的值减直接地址的值减借 位C,结果存回累加器
1 1 将累加器的值减间接地址的值减借
A,@Ri 12.SUBB A,0data
位C,结果存回累加器 2 1 将累加器的值减常数值减借位C,结
果存回累加器
13.INC A 1 1 将累加器的值加1 14.INC Rn 1 1 将寄存器的值加l
51汇编语言指令集
符号定义表
符号
含义
Rn
R0~R7寄存器n=0~7
Direct 直接地址,内部数据区的地址 RAM(00H~7FH)
SFR(80H~FFH) B,ACC,PSW,IP,P3,IE,P2,SCON, P1,TCON,P0
@Ri
间接地址Ri=R0或R1
8051/31RAM地址
(00H~7FH) 8052/32RAM地址(00H~FFH)
44.CPL A 1 1 将累加器的值反相
45.RL A 1 1 将累加器的值左移一位
46.RLC A 1 1 将累加器含进位C左移一位
47.RR A 1 1 将累加器的值右移一位
48.RRC A 1 1 将累加器含进位C右移一位
49.SWAP 1 1 将累加器的高4位与低4位的内容交换。
  1. 1、下载文档前请自行甄别文档内容的完整性,平台不提供额外的编辑、内容补充、找答案等附加服务。
  2. 2、"仅部分预览"的文档,不可在线预览部分如存在完整性等问题,可反馈申请退款(可完整预览的文档不适用该条件!)。
  3. 3、如文档侵犯您的权益,请联系客服反馈,我们会尽快为您处理(人工客服工作时间:9:00-18:30)。

(算术运算
商,AH←AX÷src 余 8 位 mem (86~96)+EA
指令)
数,Src 字 AX←DX 16 位 reg 144 ~ 162
AX÷src 商,DX←DX 16 位 mem (150~168)+EA
AX÷src 余数
IDIV src Src 字节AL←AX÷src 8 位 reg 101 ~ 112
经计算才能得到操作 (AL)←((DS)×16+(SI)+OFFSET)

MOV AX,[BX+DI];
(AX)←((DS)×16+(BX)+(DI))
1
8086 汇编总结 相对基址变址寻址
PA=(DS|SS)×16+ (BX|BP)+(SI|DI)+偏移量
程伟整理 MOV AX, OFFSET (BX+DI); (AX)←((DS)×16+(BX)+(DI)+OFFS ET)
标志 F 标志寄存器
,
标志寄存器
总线 段 接口 寄 部件 存 BIU 器
CS 代码段 DS 数据段 ES 附加段 SS 堆栈段
不能被赋值 复位后为 FFFFH 复位后为 0000H
存放堆栈基地址
存储器
IP IP 指令指针寄存器器
指令指针寄存器
二、状态标志寄存器 F
标志位名
功能
为 1 对应符
为 0 对应符
16+EA 9+EA
指令)
reg, reg
3
reg, imm 4
mem, imm 17+EA
SBBdest ,src
(dst) ← (src) - (dst) - mem, reg
CF
reg, mem
16+EA 9+EA
带进位减法
reg, reg
3
reg, imm 4
mem, imm 17+EA
DEG dest (dest) ← (dest) - 1
寄存器相对寻址
基址变址寻址
操作数在指令中直接给出 操作数在寄存器中 操作数的有效地址由指令直接给出 PA=(DS)|(SS)×16+
(BX)|(SI)|(DI)|(BP) PA=(DS|SS)×16+
(BX|BP|SI|DI)+偏移量 PA=(DS|SS)×16+
(BP|BX)+(SI|DI)
源操作数为地址 操作数需要寻址
商,AH←AX÷src 余 8 位 mem (107~118)+EA
数,Src 字 AX←DX 16 位 reg 165 ~ 184
AX÷src 商,DX←DX 16 位 mem (171~190)+EA
AX÷src 余数
加 (算术运算
ADD dst, src (dst) ← (src) + (dst)
符,有进位为 1,否 reg, reg
3
则为 0)
reg, imm 4
mem, imm 17+EA
acc, imm 4
INC dest (dest) ← (dest)+1
reg mem
2~3 15+EA
减 (算术运算
SUB dest, src (dst) ← (src) - (dst)
mem, reg reg, mem
3
8086 汇编总结
程伟整理
标志传送指 令
LAHF 取标志
(AH) ← (F 低 8 位字 隐含操作 4
节)

1
F
15
7 SF
(唯一对 F SAHF 置标志
(F 低 8 位字节) ← 隐含操作 4
1
14
6 ZF
寄存器操作)
(AH)

13
5
PUSHF 标志入 (SP) ← (SP)-2(先入 隐含操作 10
8086 汇编总结
程伟整理
8086 汇编_总结
一、8086 编程结构
执 通 AX 累加器
行 用 BX 基数寄存器
部 寄 CX 计数器

存器 DX
数据寄存器
EU
专 BP 基数指针
用 SP 堆栈指针
给出栈顶偏移地址
寄 SI 源变址寄存器
存器 DI
目的变址寄存器
数据寄存器
指针寄存器 堆栈段偏移地址 变址寄存器 数据段偏移地址
类型
汇编指令格式


操作数说 时钟周期数 字节数
说明

辅助运算指
CBW
AX←AL
字节扩展
不影响标志位

到字
AL<80H 时 AH=00H , AL>=80H 时 AH=FFH
CWD
DXAX←AX
字扩展到 双字
AX<8000H 时 DX=0000H, DX=FFFFH
AX>=8000H 时
对于符号数:最高位为 0 表示正,为 1 表示负
NV

DF
方向标志
DN
UP
IF
中断允许标志
控制标志位
EI
DI
TF
跟踪标志
三、寻址方式{(PA 物理地址=实际地址=绝对地址=cpu 以实际地址访问存储器)
=段基址*10H+(逻辑地址=偏移地址=有效地址 EA=程序以逻辑地址编址)}
寻址方式
操作数物理地址(PA)
指令格式举例
立即寻址 寄存器寻址 直接寻址 寄存器间接寻址
B
DAA
(AL) ← (AX) / (src)
4
1
C
压缩 BCD 数 的商
D
加法调整
(AH) ← (AX) / (src)

的余数

(AX) ← (DX, AX) /

(src) 的商

(DX) ← (DX, AX) /

(src) 的余数

DAS
(AL) ← (AX) / (src)
4
1

压缩 BCD 数 的商
AAM
(AL) ← AL 中的和调整
83
2
乘法
为非组合BCD
ASCII 码调整 (AH) ← (AH)+调整
产生的进位值
4
8086 汇编总结
AAD
(AL) ← AL 中的差调整
60
除法
为非组合BCD
ASCII 码调整 (AH) ← (AH)-调整产 生的进位值

DIV src
Src 字节AL←AX÷src 8 位 reg 80 ~ 90
OUT port,DX
((DX)) ← (acc)
reg, mem reg, reg mem, reg
17+EA 4 3 11
AX 字节, 10
AL 字, 10 DX 不是 8 操作数而 8 是地址
LEA reg, src 取 有效地址指令 LDS reg, src 地 址指针装入 DS
LES reg, src 地址 指针装入 ES
1
12
4 AF
栈指令
栈)
数,标志
((SP)+1, (SP)) ← F
寄存器入 栈
POPF 标志弹出 F← ((SP)+1, (SP)) 隐含操作 8
指令
(SP) ← (SP)+2(出栈) 数,数据
11 OF 3
10 DF 2 PF
9 IF 1
1
8 TF 0 CF
出栈到标
志寄存器
2、算术运算指令 (都对 F 寄存器产生影响)
XCHG dest, src 数据交换指令
(des) ←→ (src)
XLAT 换码指令
AL←DS 中逻辑地址 为(BX+AL)的内存单 元
IN AL/AX, port (acc) ← (port)
OUT port, AL/AX (port) ← (acc)
IN AL/AX,DX
(acc) ← ((DX))
B——二进制
D——十进制
Q——八进制
H——十六进制
四、符号约定及含义
符号
含义
i8
一个 8 位立即数
i16
一个 16 位立即数
imm
一个 8 位或 16 位立即数
r8
一个 8 位通用寄存器

r16
一个 16 位通用寄存器或专用寄存器
reg
一个 8 位或 16 位通用寄存器或专用寄存器
seg
一个 16 位段寄存器
CF 进位标志
1 最高位产生进位
CY
NC
AF 辅助进位标志
1 低四位产生进位
AC
NA
ZF 零标志
1 结果为 0
,0 结果不为 0
ZR
NZ
SF 符号标志
1 结果为负
,0 结果为正
NG
PL
PF 奇偶标志
1 底八位有偶数个 1,0 结果有奇数个
PE
PO
1
OF 溢出标志
1 最高位有进位 ,0 最高位没进
OV
基地址在 ss 中 偏移地址在 sp 中 调用或中断时保存返回地 址 两者互换,但不能同时为 存储器操作数,存储内容 互换要借助通用寄存器
操作数均隐含
直接寻址,port 地址范围 0-255(0ffh) 间接寻址,端口地址在 DX 中,范围 065535(0ffffh)
L 为取的意思 操作数均为 16 位
相关文档
最新文档