汇编语言.docx
《汇编语言.docx》由会员分享,可在线阅读,更多相关《汇编语言.docx(39页珍藏版)》请在冰豆网上搜索。
汇编语言
汇编语言重点知识总结(超全的哦~~)
汇编速查手册汇编语言总结概要
寄存器与存储器
1.寄存器功能
.寄存器的一般用途和专用用途
.CS:
IP控制程序执行流程
.SS:
SP提供堆栈栈顶单元地址
.DS:
BX(SI,DI)提供数据段内单元地址
.SS:
BP提供堆栈内单元地址
.ES:
BX(SI,DI)提供附加段内单元地址
.AX,CX,BX和CX寄存器多用于运算和暂存中间计算结果,但又专用于某些指令(查阅指令表)。
.PSW程序状态字寄存器只能通过专用指令(LAHF,SAHF)和堆栈(PUSHF,POPF)进行存取。
2.存储器分段管理
.解决了16位寄存器构成20位地址的问题
.便于程序重定位
.20位物理地址=段地址*16+偏移地址
.程序分段组织:
一般由代码段,堆栈段,数据段和附加段组成,不设置堆栈段时则使用系统内部的堆栈。
3.堆栈
.堆栈是一种先进后出的数据结构,数据的存取在栈顶进行,数据入栈使堆栈向地址减小的方向扩展。
.堆栈常用于保存子程序调用和中断响应时的断点以及暂存数据或中间计算结果。
.堆栈总是以字为单位存取
指令系统与寻址方式
1.指令系统
.计算机提供给用户使用的机器指令集称为指令系统,大多数指令为双操作数指令。
执行指令后,一般源操作数不变,目的操作数被计算结果替代。
.机器指令由CPU执行,完成某种运算或操作,8086/8088指令系统中的指令分为6类:
数据传送,算术运算,逻辑运算,串操作,控制转移和处理机控制。
2.寻址方式
.寻址方式确定执行指令时获得操作数地址的方法
.分为与数据有关的寻址方式(7种)和与转移地址有关的寻址方式(4)种。
.与数据有关的寻址方式的一般用途:
(1)立即数寻址方式--将常量赋给寄存器或存储单元
(2)直接寻址方式--存取单个变量
(3)寄存器寻址方式--访问寄存器的速度快于访问存储单元的速度
(4)寄存器间接寻址方式--访问数组元素
(5)变址寻址方式
(6)基址变址寻址方式
(7)相对基址变址寻址方式
(5),(6),(7)都便于处理数组元素
.与数据有关的寻址方式中,提供地址的寄存器只能是BX,SI,DI或BP
.与转移地址有关的寻址方式的一般用途:
(1)段内直接寻址--段内直接转移或子程序调用
(2)段内间接寻址--段内间接转移或子程序调用
(3)段间直接寻址--段间直接转移或子程序调用
(4)段间间接寻址--段间间接转移或子程序调用
汇编程序和汇编语言
1.汇编程序
.汇编程序是将汇编语言源程序翻译成二进制代码程序的语言处理程序,翻译的过程称为汇编。
2.汇编语言
.汇编语言是用指令助记符,各种标识变量,地址,过程等的标识符书写程序的语言,汇编语言指令与机器指令一一对应。
.伪指令,宏指令不是由CPU执行的指令,而是由汇编程序在汇编期间处理的指令。
.伪指令指示汇编程序如何完成数据定义,存储空间分配,组织段等工作。
.宏指令可简化程序并减少程序书写量。
.条件汇编伪指令的功能是确定是否汇编某段源程序,而不是实现程序分支,对未汇编的程序将不产生相应的目标代码。
.结构作为一种数据结构可将一组类型不同但有逻辑关联的数据组织在一起,便于整体处理数据。
.记录可用于提高存储单元的利用率,将若干不足一个字节或字且有逻辑关联的信息压缩存放在一个字节或字中。
.指令中的表达式在汇编期间计算,并且只能对常量或地址进行计算。
程序设计基础
1.分支程序设计
.程序分支由条件转移指令或无条件转移指令实现
.存放若干目的转移地址或跳转指令的跳转表常用于实现多路分支
.条件转移指令只能实现偏移量为-128至+127字节范围的转移
.无条件转移指令根据寻址方式可实现短转移(偏移量为-128至+127字节),段内转移,段间转移。
2.循环程序设计
.可由循环控制指令或条件转移指令组织循环结构
.内层循环结构必须完全包含在外层循环结构内,并不能发生从循环结构外向循环结构内的转移。
3.子程序设计
.子程序中应保护寄存器内容,并正确使用堆栈,成对执行PUSH和POP指令,保证执行RET指令时堆栈栈顶为返回地址。
.主程序可通过寄存器,参数表,或堆栈传递参数给子程序
4.EXE文件和COM文件
.二者都是可执行文件
.COM文件源程序的特点是:
第一条可执行指令的起始存放地址必须是100H,不能分段,不用定义堆栈,所有过程为NEAR类型,直接用INT20H指令返回DOS。
5.DOS功能调用与BIOS中断调用
.二者都是完成DOS系统提供给用户的输入/输出等常用功能,通过执行软中断指令完成一次软中断服务。
.DOS功能调用的中断服务程序是操作系统的一部分,存于RAM中;而BIOS中断调用的中断服务程序存放在ROM中。
输入/输出与中断系统
1.输入/输出的方式
.程序直接I/O方式:
用IN和OUT指令直接在端口级上进行I/O操作,数据传送方式分为无条件传送方式和查询传送方式。
.中断传送方式:
由CPU响应中断请求完成中断服务。
.DMA传送方式:
直接在存储器与外设之间传送数据。
2.有关中断的概念
.中断、中断源、中断请求、中断服务、中断向量、中断向量表、中断响应过程、中断指令、开中断、关中断、内部中断、外部中断、可屏蔽中断、非屏蔽中断。
3.键盘I/O、显示器I/O操作
.键盘的输入操作用BIOS的16H中断调用控制,也可直接访问60H端口(数据端口),61H端口(状态端口)检测键盘的按键操作。
.对于特殊键(如Shift,Ctrl,Alt,NumLock,ScrollLock等键)的按动情况,可以直接从来40:
17H单元取得有关信息。
.显示器的图形显示可以用BIOS的10H中断调用实现,另一种速度更快的方法是直接读写视频缓冲区。
4.打印机I/O操作由INT17H中断调用实现,串行通讯口操作由INT14H中断调用实现。
CLDClearthedirectionflag(settoforwarddirection)
将方向标志置0,使si和di增量,串处理从低地址向高地址处理
8088汇编速查手册
一、数据传输指令
它们在存贮器和寄存器、寄存器和输入输出端口之间传送数据.
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 装入有效地址.
例:
LEADX,string ;把偏移地址存到DX.
LDS 传送目标指针,把指针内容装入DS.
例:
LDSSI,string ;把段地址:
偏移地址存到DS:
SI.
LES 传送目标指针,把指针内容装入ES.
例:
LESDI,string ;把段地址:
偏移地址存到ES:
DI.
LFS 传送目标指针,把指针内容装入FS.
例:
LFSDI,string ;把段地址:
偏移地址存到FS:
DI.
LGS 传送目标指针,把指针内容装入GS.
例:
LGSDI,string ;把段地址:
偏移地址存到GS:
DI.
LSS 传送目标指针,把指针内容装入SS.
例:
LSSDI,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次.
移位一次时,可直接用操作码. 如SHLAX,1.
移位>1次时,则由寄存器CL给出移位次数.
如 MOVCL,04
SHLAX,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的距离内)
(当且仅当(SFXOROF)=1时,OP1 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 程序结束.
本文转至:
个人总结:
现在正在学习汇编程序个人认为它和c#结合是个很不错的选择,故收录着先有空就慢慢品味!
~~^_^
汇编语言基本操作训练(4)
汇编语言,训练
实验四 汇编语言基本指令操作练习
一、实验目的:
1、掌握8086/8088基本指令的使用方法和功能。
2、初步了解汇编语言程序设计的基本结构和利用DEBUG调试
程序的方法。
3、进一步熟悉汇编语言的上机过程。
二、上机实验指导:
(一)利用DEBUG的A命令输入指令,做如下实验。
1、 比较下面指令的区别:
①MOVAX,2000H ②MOVBX,[2000H]
-D20002001 ;显示字存储单元DS:
2000的内容
3ADC:
2000 5A58 ZX
-R ;显示指令执行前AX,BX的内容
AX=0000BX=0000CX=0000DX=0000SP=FFEEBP=0000SI=0000DI=0000
DS=3ADCES=3ADCSS=3ADCCS=3ADCIP=0100NVUPEIPLNZNAPONC
3ADC:
0100858CFFF3 TEST CX,[SI+F3FF] DS:
F3FF=74C0
-A ;利用A命令输入汇编指令
3ADC:
0100MOVAX,2000
3ADC:
0103MOVBX,[2000]
3ADC:
0107INT3 ;此中断为断点中断,使程序执行暂停
3ADC:
0108
-G ;不指定地址,从当前CS:
IP处执行
AX=2000BX=585ACX=0000DX=0000SP=FFEEBP=0000SI=0000DI=0000
DS=3ADCES=3ADCSS=3ADCCS=3ADCIP=0107NVUPEIPLNZNAPONC
3ADC:
0107CC INT3 ;指令执行后,AX=2000H,BX=585AH
2、以寄存器BX作为地址指针,从BX所指的存储单元开始起,连续存放着
两个无符号数(字操作数),编程求它们的和,并将结果存放在这两个数
之后。
-RBX ;显示BX寄存器中的内容(BX=0000h)
BX0000
:
;回车
-D00000005 ;显示DS:
0000到DS:
0005的内容(BX所指的三个
字操作数),如BX不为0000H,自己修改范围。
3A6B:
0000 CD20FF9F009A .....
;三个字操作数依次为20CDH,9FFFH,9A00H
-A ;输入指令
3A6B:
0100 MOVAX,[BX]
3A6B:
0102 INCBX
3A6B:
0103 INCBX
3A6B:
0104 ADDAX,[BX]
3A6B:
0106 INCBX
3A6B:
0107 INCBX
3A6B:
0108 MOV[BX],AX
3A6B:
010A INT3
3A6B:
010B
-G ;运行此程序
AX=C0CCBX=0004CX=0000DX=0000SP=FFEEBP=0000SI=0000DI=0000
DS=3A6BES=3A6BSS=3A6BCS=3A6BIP=010ANVUPEIPLNZNAPONC
3A6B:
010ACC INT 3
-D00000005 ;观察运行结果,检查第三个字操作数是否为前两个
字操作数之和
3A6B:
0000 CD20FF9FCCC0 .....
3、在屏幕上显示大写字符”A”。
-A
1277:
0100 mov ah,2
1277:
0102 mov dl,41 ;大写字符”A”的ASCII值为41H
1277:
0104 int 21
1277:
0106 int 3
1277:
0107
-G
A ;显示大写字符”A”
AX=0241BX=0000CX=0000DX=0041SP=FFEEBP=0000SI=0000DI=0000
DS=1277ES=1277SS=1277CS=1277IP=0106 NVUPEIPLNZNAPONC
1277:
0106CC INT 3
三、实验步骤
1、按照上机实验指导的内容,练习三个程序的运行和调试。
2、用DEBUG的A命令输入指令,完成以下功能:
已知(AL)=50H,(BL)=18H,计算AL-BL,并将存入CL中。
输入指令后,运行调试,观察运行结果。
-a
1277:
0100mov al,50
1277:
0102mov bl,18
1277:
0104sub al,bl
1277:
0106mov cl,al
1277:
0108int 3
1277:
0109
-g ;观察寄存器AX,BX,CX的内容
AX=0038 BX=0018 CX=0038DX=0000SP=FFEEBP=0000 SI=0000 DI=0000
DS=1277 ES=1277 SS=1277 CS=1277 IP=0108 NVUPEIPLNZACPONC
1277:
0108CC INT 3
3、用DEBUG的A命令输入指令,完成以下功能:
输入一个大写字母,将其转换为小写字母后输出。
编好程序后,用DEBUG调试、运行程序。
-a
1277:
0100mov ah,1
1277:
0102int 21
1277:
0104add al,20
1277:
0106mov dl,al
1277:
0108mov ah,2