微机原理与接口技术汇编语言指令详解吐血版
微机原理与接口技术第3章汇编语言程序设计ppt课件
存储器寻址方式
◆段址寄存器:内存逻辑地址的段基址存放的寄存器(CS, SS, DS, ES)。 ◆偏移址寄存器:基址寄存器(BX, BP), 变址寄存器(SI, DI)。
◆内存逻辑地址的偏移地址(EA)寻址方式:
直接寻址方式:
指令中直接给出EA
寄存器间接寻址方式: EA =(基/变址R)
寄存器相对寻址方式: EA =(基/变址R)+〈位移量〉 基址变址寻址方式: EA =(基址R)+ (变址R) 基址变址相对寻址方式:EA =(基址R)+ (变址R)+ 〈位移量〉
乘法运算指令
无符号乘法指令MUL 有符号乘法指令IMUL
格式: MUL src
IMUL src
操作数寻址:src = reg|mem
操作:有/无符号数的乘法
字节乘法:(AL)×(src)→AX
字乘法: (AX)×(src)→DX|AX(32位)
注意:被乘数和乘积是固定寻址,只需给出乘数。
例如:
无符号数字节乘法(255×1 ) 0FFH×1= 00FFH
IMUL AL
;有符号数 (AL)×(AL)→AX
IMUL CX
;有符号数 (AX)×(CX)→DX|AX
例如:计算(-104)除以25。
MOV AL,-104 CBW
;AL=-104(98H) ;AL扩展为 AX (0FF98H)
MOV BL,25 IDIV BL
;BL=25 ;AL=-4(商),AH=-4(余数)
CWD 字符号扩展
◆算术运算类指令基本都均影响标志位(ZF、SF、CF、OF)。
◆绝大多数是双操作数,操作数可为字节/字类型。
◆寻址方式与MOV 指令基本相同。
微机原理与接口技术第3章(指令部分)
例:编程计算 0+1+2+3+4+ -----10 编程计算
MOV AL,0 , MOV BL,1 , MOV CL,10 NEXT:ADD AL,BL , INC BL DEC CL JNZ NEXT ;CL≠0 转 ≠ HLT
1
3.1 概述 一、指令包含的基本内容
12
(3)相对寻址
例: MOV AX, [SI+100H]
;结果 : 结果 AX (DS×16+SI+100H) ×
例:MOV AL,[BP+DATA] MOV AL, DATA[BP] ; DATA是符号表示的位移量。 表示的位移量 是符号表示的位移量。
结果 : AL (SS×16+BP+DATA) ×
11
(2)间接寻址 例:MOV AX,[BX] , •结果 : AX 结果 (DS×16+BX) ×
...
3000H:0000H : • EA= BX /SI /DI , 物理地址=DS*16+EA 物理地址 • EA= BP 物理地址=SS*16+EA 物理地址 :1234H :50H :1235H :30H
1. 做什么操作? 做什么操作? MOV ,ADD, OR,CMP等助记符 等助记符
2. 操作的数据是什么? ①CPU内的寄存器; 操作的数据是什么? 内的寄存器 内的寄存器; 内存的某一个或几个单元 单元; ②内存的某一个或几个单元; 结果放在那里? 3. 结果放在那里? 立即数。 ③立即数。 端口; 端口 ④I/O端口; 下一条指令在哪里? 4. 下一条指令在哪里? IP←IP+1
微机原理与接口技术-汇编语言程序设计
4.1.2 8086汇编语言源程序的格式
源程序的一般格式为: NAME1 SEGMENT
语句 语句 NAME1 ENDS NAME2 SEGMENT 语句 语句 NAME2 ENDS END <标号>
第四章 汇编语言 程序设计
4.2 语句的格式
第四章 汇编语言 程序设计
汇编语句分为指令语句和伪指令语句两类,一般都由分 隔符分成的 4 个部分组成。
HLT
;然后停机
NOT DONE : IN AL, PORT_VAL ;未超过时,输入下一字节
ADD SUM, AL
;与以前的结果累加
JMP CODE ENDS ;代码段结束
END START
;整个程序结束
可以看到,8086汇编的一个语句行是由4个部分组成,即
标号 操作码 操作数 ;注释(或名字)
普通高等学校计算机教育“十三五”
微机原理与接口技术
内容导航
CONTENTS
4.1 汇编语言的格式 4.2 语句的格式 4.3 伪指令语句 4.4 指令语句 4.5 汇编语言程序设计及举例
4.1 汇编语言的格式
4.1.1 8086汇编语言的一个例子
第四章 汇编语言 程序设计
MY_DATA SEGMENT ;定义数据段
SUM DB ?
;为符号 SUM 保留一个字节
MY_DATA ENDS
;定义数据段结束
MY_CODE SEGMENT ;定义码段
ASSUME CS :MY_CODE, DS :MY_DATA
;规定 CS 和 DS 的内容
PORT_VA1 EQU 3
;端口的符号名
START :MOV AX, MY_DATA ;DS 初始化为 MY_DATA
汇编语言指令集合吐血整理
汇编语言指令集合吐血整理汇编语言是一种低级程序设计语言,用于直接控制计算机硬件。
在汇编语言中,指令是程序的基本单位,它告诉计算机执行的操作。
本文将汇编语言常用指令进行吐血整理,帮助读者更好地理解和运用这些指令。
一、数据传送指令数据传送指令用于将数据从一个地方传送到另一个地方,完成数据的读取和存储操作。
常见的数据传送指令包括:1. MOV:将数据从一个位置复制到另一个位置。
语法形式为MOV 目的操作数, 源操作数。
例如:MOV AX, BX 表示将寄存器BX中的数据复制到寄存器AX中。
2. PUSH:将数据压入堆栈。
语法形式为PUSH 操作数。
例如:PUSH AX 表示将AX寄存器中的数据压入堆栈。
二、算术运算指令算术运算指令用于对数据进行基本的算术运算,包括加法、减法、乘法和除法。
常见的算术运算指令包括:1. ADD:将两个操作数相加,并将结果存储到目的操作数中。
语法形式为ADD 目的操作数, 源操作数。
例如:ADD AX, BX 表示将寄存器AX和BX中的数据相加,并将结果存储到AX中。
2. SUB:将源操作数的值从目的操作数中减去,并将结果存储到目的操作数中。
语法形式为SUB 目的操作数, 源操作数。
例如:SUB AX, BX 表示将寄存器BX中的值从AX中减去,并将结果存储到AX中。
三、逻辑运算指令逻辑运算指令用于对数据进行与、或、非等逻辑运算。
常见的逻辑运算指令包括:1. AND:对两个操作数进行逻辑与运算,并将结果存储到目的操作数中。
语法形式为AND 目的操作数, 源操作数。
例如:AND AX, BX表示将寄存器AX和BX中的数据进行逻辑与运算,并将结果存储到AX中。
2. OR:对两个操作数进行逻辑或运算,并将结果存储到目的操作数中。
语法形式为OR 目的操作数, 源操作数。
例如:OR AX, BX 表示将寄存器AX和BX中的数据进行逻辑或运算,并将结果存储到AX中。
四、流程控制指令流程控制指令用于控制程序的执行流程,包括条件分支和循环等。
微型计算机原理及接口技术第3章 80X86指令系统及汇编语言
第3章 80X86指令系统及汇编语言
..
操作码 2000 ∶ 0FFFH 50H 2000∶ 1000H
2000 ∶ 1050H 操作码
CS + IP +
20 00 10 00
50 21 05 0
.. .. ..
图3.8 段内相对寻址
第3章 80X86指令系统及汇编语言
2.段内间接寻址 在段内间接寻址方式中,转移地址的段内偏移地 址要么存放在一个16位的寄存器中,要么存放在存贮 器的两个相邻单元中。存放偏移地址的寄存器和存贮 器的地址将按指令码中规定的寻址方式给出。此时, 寻址所得到的不是操作数,而是转移地址。 例:JMPCX 其过程如图3.9所示。
第3章 80X86指令系统及汇编语言
3.1.2转移地址的寻址方式 1.段内相对寻址 在段内相对寻址方式中,指令应指明一个8位或16
位的相对地址位移量DISP(有正负符号, 用补码表示)。此时,转移地址应该是代码段寄存
器CS内容加上指令指针IP内容,再加上相对地址位移 量DISP。
例:JMPDISP1 其过程如图3.8所示。
第3章 80X86指令系统及汇编语言
2.交换指令 XCHG OPRD1,OPRD2 交换指令把一个字节或一个字的源操作数与目的 操作数相交换。这种交换能在通用寄存器与累加器之 间、通用寄存器之间、通用寄存器与存贮器之间进行, 但是段寄存器不能作为一个操作数。例如:
XCHGAL,CL XCHGAX,DI XCHGBX,SI XCHGAX,BUFFER XCHGBX,DATA[SI]
第3章 80X86指令系统及汇编语言
立即数
段寄存器 CS,DS,SS,ES
通用寄存器 AX,BX,CX,DX,BP,SP,SI,DI AH,AL,BH,BL,CH,CL,DH,DL
微机原理与接口技术编程指令分析(较详细)
微机原理与接⼝技术编程指令分析(较详细)编程指令分析1、求累加器AX和寄存器BX中两个⽆符号数之差的绝对值,结果送外设2000HMOV CX,AX ;保存AXSUB AX,BX ; AX-BX AX变了JC AA ;CF=1,最⾼位有借位,AXOUT DX,AX ;HLT ;CPU进⼊暂停状态。
AA:SUB BX,CX ;BX=( BX-CX(AX) )MOV AX,BXJMP BB3、若在某数据段2000H开始的48个单元中,存放着某班48个同学的数学课考试成绩。
试编写程序找出该班的最⾼分,将其置于BL中MOV CX,2FHMOV SI,2000HMOV BL,[SI]BB:INC SIMOV AL,[SI]SUB AL,BLJC AA ;有借位,ALMOV BL,[SI] ;AL>=BL,BL=ALAA:LOOP BBHLT4、编程序将存从4000:0000H到4000:00FFH的每个单元中均写⼊55HMOV AX,4000HMOV ES,AX ;段地址赋初值MOV CX,100H ;00FFH=100DMOV DI,0H ;MOV AL,55HCLDREP STOSB ;HLT(若改为字节操作,则“100H”→128D;“AL,55H”→AX,5555H;STOSB→STOSW)5、从外设500H单元中读取⼀个字节M,判断其值是否在70H和80H之间,即70H≤M <80H。
如果M≥80H,则送0FFH给外设端⼝502H;如果M<70H,则送00H给外设端⼝502H;如果70H≤M<80H,则送88H给外设端⼝502HSTART:MOV DX,500H ;端⼝地址IN AL,DX ;从外部端⼝输⼊容到ALCLC ;清零借位标志CFCMP AL,70H ;AL-70HJC LP1 ;CF=1有借位,AL<70H,转LP1 CMP AL,80H ;AL>=70H,AL-80H JC LP2 ;70HMOV AL,0FFH ;AL>=80H,AL=0FFH(第⼀个16进制数为字母的,前⾯加0,以区别程序中的变量)LP3:MOV DX,502H ;输出端⼝地址赋到DX中OUT DX,AL ;将结果传送到外部端⼝HLTLP1:MOV AL,00HJMP LP3LP2:MOV AL,88HJMP LP3单元START:MOV AX,@DATAMOV DS,AX ;DS段初始化MOV AX,XCMP AX,YJGE L1 ;X>=Y,转L1MOV AX,Y ;X<=Y,⼤数Y赋到AX中L1:CMP AX,Z ;AX-Z,JGE L2 ;AX>=Z,转L2MOV AX,Z ;AXL2:MOV MAX,AX ;最⼤数赋到MAX存储单元7、若在3000:3000H和3000:3001H单元有两个⽆符号数,编⼀个程序⽐较它们的⼤⼩,把⼤的数放在3000:3002H单元START:MOV AX,3000HMOV DS,AX ;段地址赋初值MOV AL,[3000H] ;低地址单元容 AL←(DS×16+3000)CMP AL,[3001H] ;两容相⽐较JAE L ;(above and equal)AL>=⾼XCHG AL,[3001H] ;AL<⾼的,交换L:MOV [3002H],ALHLT8、设X、Y、Z、W均为存放16位带符号数单元的地址。
微机原理与接口技术 指令系统整理
微机原理与接口技术指令系统整理一、引言微机原理与接口技术是计算机科学与技术专业中的重要课程之一,它主要介绍了微机的基本原理和接口技术。
其中,指令系统是微机的核心组成部份,它定义了微机的指令集和指令的执行方式。
本文将对微机原理与接口技术中的指令系统进行整理和总结,旨在匡助读者更好地理解和掌握微机的指令系统。
二、指令系统概述1. 定义指令系统是计算机硬件与软件之间的接口,它定义了计算机的指令集和指令的执行方式。
指令系统包括指令的格式、指令的编码方式、指令的功能等内容。
2. 指令集指令集是指计算机所能执行的所有指令的集合。
常见的指令集有精简指令集(RISC)和复杂指令集(CISC)等。
3. 指令的格式指令的格式包括操作码、操作数和寻址方式等部份。
操作码用于指示所执行的操作,操作数用于指定操作的对象,寻址方式用于确定操作数的地址。
4. 指令的编码方式指令的编码方式决定了指令在计算机内部的表示方式。
常见的编码方式有二进制编码、十进制编码和十六进制编码等。
5. 指令的功能指令的功能包括数据传送、算术运算、逻辑运算、控制转移等。
不同的指令可以实现不同的功能。
三、指令系统分类1. 指令的类型指令可以根据其功能和操作对象的不同进行分类。
常见的指令类型有数据传送指令、算术运算指令、逻辑运算指令、控制转移指令等。
2. 指令的寻址方式指令的寻址方式决定了指令如何获取操作数的地址。
常见的寻址方式有即将寻址、直接寻址、间接寻址、寄存器寻址等。
3. 指令的执行顺序指令的执行顺序决定了指令的执行顺序和流程。
常见的执行顺序有顺序执行、条件执行、循环执行等。
四、指令系统设计原则1. 简洁性原则指令系统应尽量简洁,避免冗余和复杂的指令,以提高执行效率和降低设计成本。
2. 完备性原则指令系统应包含常用的指令,能够满足大部份应用需求。
3. 兼容性原则指令系统应与硬件和软件环境兼容,以便于系统的扩展和升级。
4. 可扩展性原则指令系统应具有良好的扩展性,能够支持新的指令和功能的添加。
微机原理与接口技术汇编语言指令详解吐血版
第一讲第三章 指令系统--寻址方式回顾: 8086/8088的内部结构和寄存器,地址分段的概念,8086/8088的工作过程。
重点和纲要:指令系统--寻址方式。
有关寻址的概念;6种基本的寻址方式及有效地址的计算。
教学方法、实施步骤时间分配 教学手段 回 顾 5”×2 板书 计算机 投影仪 多媒体课件等讲 授 40” ×2 提 问 3” ×2 小 结2” ×2讲授内容:3.1 8086/8088寻址方式首先,简单讲述一下指令的一般格式:操作码 操作数 …… 操作数计算机中的指令由操作码字段和操作数字段组成。
操作码:指计算机所要执行的操作,或称为指出操作类型,是一种助记符。
操作数:指在指令执行操作的过程中所需要的操作数。
该字段除可以是操作数本身外,也可以是操作数地址或是地址的一部分,还可以是指向操作数地址的指针或其它有关操作数的信息。
寻址方式就是指令中用于说明操作数所在地址的方法,或者说是寻找操作数有效地址的方法。
8086/8088的基本寻址方式有六种。
1.立即寻址所提供的操作数直接包含在指令中。
它紧跟在操作码的后面,与操作码一起放在代码段区域中。
如图所示。
例如:MOV AX ,3000H立即数可以是8位的,也可以是16位的。
若是16位的,则存储时低位在前,高位在后。
立即寻址主要用来给寄存器或存储器赋初值。
2.直接寻址操作数地址的16位偏移量直接包含在指令中。
它与操作码—起存放在代码段区域,操作数一般在数据段区域中,它的地址为数据段寄存器DS加上这16位地址偏移量。
如图2-2所示。
例如: MOV AX,DS:[2000H];图2-2(对DS来讲可以省略成 MOV AX,[2000H],系统默认为数据段)这种寻址方法是以数据段的地址为基础,可在多达64KB的范围内寻找操作数。
8086/8088中允许段超越,即还允许操作数在以代码段、堆栈段或附加段为基准的区域中。
微机原理与接口技术第3章 汇编语言与程序设计03
① 标号:是由字母开头的字符串组成,以冒号“:”结束,表示一 条指令的符号地址。标号最长31个字符,由字母A~Z、数字0~9和 一些特殊字符?、.、@、_、$组成。但是数字不能作为标号的第一 个字符,圆点仅能用作标号第一个字符。 ② 助记符:表示操作性质的指令,如果带有前缀,用空格分开。 ③ 操作数:指令操作的对象,按指令要求,可能有一个、两个或者 没有。操作数有两个时用逗号“,”分开。操作数可以是常数、寄存 器名、标号、变量或表达式等。 ④ 注释:以分号“;”开头,是对语句或程序的说明,仅在源程序 清单中列出,不作其它处理。 (2)伪指令语句 是一种说明性的语句,用来对汇编过程进行控制,比如对数据列表、 存储空间分配、程序起始地址及段定义等,汇编时不生成目标代码。 伪指令语句格式如下:
[符号名] 伪指令 [参数] [;注释] ① 符号名:同标号,但是后面没有冒号“:”,在不同的伪指令语 句中,符号名可以是常量名、变量名、过程名、段名、结构名、记录 名等。 ② 伪指令:是要求汇编程序完成具体操作的命令,比如数据定义伪 指DB、DW、DD等,段定义伪指令SEGMENT和ENDS等。 ③ 参数:是对汇编过程的进一步说明,可以是常量、变量、标号、 过程名、结构名、记录名或一些专用符号,比如BYTE、FAR等;参 数的个数由伪指令确定。 ④ 注释:与指令语句中的注释相同。 (3)宏指令语句 宏指令是将程序中多次使用的程序段定义为一条指令,即宏指令。 在对宏指令汇编时,以原程序代码取代宏指令。宏指令格式如下: [标号:] 宏指令名 [参数1] [,参数2] [,…] [;注释 ]
3.4 汇编语言程序格式与常用伪指令
汇编语言有约定的书写格式,这就要求读者在编程时,严格遵循 约定的格式,合理使用伪指令和宏。
3.4.1 汇编语言程序格式 3.4.2 常量、变量、表达式与运算符 3.4.3 常用伪指令 3.4.4 宏指令 3.4.5 条件汇编 3.4.6 保护方式编程指令
微机原理与接口技术第四章 汇编语言程序设计说明
格式: 格式: 名字 伪指令指示符
操作数, 操作数,操作数 ;注释
关于汇编语言程序的几点说明
标号、名字与标识符 标号——用于硬指令的标识符,后跟冒号分隔。 标号——用于硬指令的标识符,后跟冒号分隔。 ——用于硬指令的标识符 名字——用于伪指令的标识符,后跟空格或制表符分隔,后面没有冒号。 名字——用于伪指令的标识符,后跟空格或制表符分隔,后面没有冒号。 ——用于伪指令的标识符 标识符(Identifier)——最多由31个字母、数字及规定的特殊符号(如 _、 标识符(Identifier)——最多由31个字母、数字及规定的特殊符号( 最多由31个字母 $、?、@)组成,不能以数字开头。默认情况下,汇编程序不区别标识符中 组成,不能以数字开头。默认情况下, 的字母大小写。 的字母大小写。 在一个程序中,每个标识符具有唯一的定义, 在一个程序中,每个标识符具有唯一的定义,并不能采用该汇编语言所定义的 保留字。 保留字。
关于汇编语言程序的几点说明
操作数与参数
处理器指令的操作数可以是立即数、寄存器和存储单元。 处理器指令的操作数可以是立即数、寄存器和存储单元。 伪指令的参数可以是常数、变量名、表达式等,可以有多个, 伪指令的参数可以是常数、变量名、表达式等,可以有多个, 参数之间用逗号分隔。 参数之间用逗号分隔。
关于汇编语言程序的几点说明
START:
NEXT:
MOV AX,DATA ;送数据段段地址 MOV DS,AX MOV AX,STACK ;送堆栈段段地址 MOV SS,AX MOV SP, OFFSET TOP ;堆栈段偏移量送SP MOV BX,OFFSET TABLE ;平方表有效地址送BX MOV DX,OFFSET BUF ;提示输入一个数 MOV AH,9 ; 9号功能调用,(显示字符串) INT 21 MOV AH,1 ;1号功能调用,(输入字符并显示) INT 21 ;键入数送入AL MOV AH,0 AND AL, 0FH ;屏蔽高四位 ADD BX,AX ;表首加偏移量 MOV AL,[BX] ;查表得平方值送AL MOV AH,4CH INT 21H RET ENDP ENDS END START ;带参数返回DOS ;返回DOS ;过程MAIN结束 ;代码段结束 ;汇编结束
微机原理与接口技术汇编语言
8086指令系统分为以下6组:⒈数据传送指令⒉算术指令⒊逻辑指令⒋串处理指令⒌控制转移指令⒍处理机控制指令数据传送指令数据传送指令的功能是把数据、地址传送到寄存器或存储器单元中。
它分为4类。
⑴通用数据传送指令⑵累加器专用传送指令MOV 传送IN 输入PUSH进栈OUT 输出POP 出栈XLAT换码XCHG交换⑶地址传送指令⑷标志寄存器传送指令LEA有效地址送寄存器LAHF标志送AHLDS指针送寄存器和DS SAHF AH送标志寄存器LES 指针送寄存器和ES PUSHF 标志进栈POPF标志出栈1 通用数据传送指令MOV dst, src;传送指令(move)执行操作:(dst) ← (src)功能:将源操作数(字节或字)传送到目的地址。
注意:●目的操作数dst和源操作数src不能同时用存储器寻址方式,这个限制适用于所有指令;● 目的操作数dst不能是CS,也不能用立即数方式;● 目的操作数dst和源操作数src不允许同时为段寄存器;● MOV指令不影响标志位。
PUSH src ; 进栈指令(push onto the stack)执行操作:(SP) ← (SP)-2((SP)) ← (src)POP dst ; 出栈指令(pop from the stack)执行操作:(dst) ← ((SP))(SP) ← (SP)+2PUSH和POP指令分别将数据存入堆栈或把堆栈中的数据取出。
堆栈是以LIFO(后进先出)方式工作的一个存储区,程序中定义的堆栈段就是这样一个LIFO存储区。
数据存入堆栈单元或从堆栈单元中取出都由堆栈指针SP指示,而SP总是指向栈顶,所以进栈和出栈指令都会自动修改SP。
PUSH指令执行时,SP的内容先减2,然后将数据压入SP所指示的字单元,存储的方法同样是高8位存入高地址字节,低8位存入低地址字节。
POP指令执行时,将SP所指示的栈顶地址的内容取出放入目的地址,然后SP增2,指向新的栈顶地址。
微机原理与接口技术 指令系统
2020/2/19
11
1 . 选 择 SI、DI、BX 作 为 间址寄存器
操作数在数据段(没有使 用段超越时)
MOV AX,[DI]
若已知(DS)=5000H, (DI)=1600H,则操作数的 物理地址为: 5000H×10H+1600H=51 600H
执行的结果为(AX)=789AH
此偏移地址也称为有效地址 EA(Effective Address),与指令的操 作码一起,存放在内存的代码段.
低8位存放在低地址单元,高8位存放在 高地址单元。
2020/2/19
7
直接寻址:
MOV AX,[3200H]
如果DS=5000H,则所 寻找的操作数的物理 地址: 5000H×10H+3200H =50000H+3200H
MOV AX,1050H[BX][SI]
2020/2/19
17
MOV AX,1050H[BX][SI] 若(BX)=2000H,(SI)=1600H,
(DS)=1200H,指令中给出的偏移量为 1050H,则源操作数的物理地址为16650H
若用BX作为基址寄存器,则段寄存器为DS,操 作数在数据段中;
POP AX指令执行示意图
2020/2/19
33
交换指令XCHG (Exchange)
指令格式及操作:
XCHG dest,src ;(dest) ←→(src)
源操作数和目标操作数均可以是寄存器或存 储器,但不能同时为存储器。即可以在寄存器 与寄存器之间、寄存器与存储器之间进行交换, 但不能在存储器与存储器之间进行交换。
若用BP作为基址寄存器,则段寄存器为SS,操 作数在堆栈段中。
微机原理与接口技术_04汇编语言程序基础讲解
2019/7/25
27
• 2.ORG伪指令
– 格式:ORG 〈表达式〉
– 功能:该指令后生成的目标代码,从表达式提供的偏移地址 开始存放。
• 3.GROUP伪指令
– 格式:〈组名〉 GROUP 〈段名1,段名2,…〉 – GROUP是群或组的意思,用来把模块中若干不同名的段集
合成一个组,并赋予一个组名,使它们都装在同一个逻辑段 中(64K)。组内各段名间的跳转都可以看作是段内跳转。 组名和段名一样,它表示该组的段地址。
– 5)SIZE运算符
– 取数组变量总字节数运算符,该运算符返回数组变量所占的总字 节数,相当于LENGTH和TYPE两个运算符返回值的乘积。
2019/7/25
16
• 5.分离运算符
– 1)LOW运算符 – 取地址表达式或16位绝对值低8位。 – 2)HIGH运算符 – 取地址表达式或16位绝对值高8位。 – 3)SHORT运算符 – 当转移指令的目标地址与该指令之间的距离在-128~127字节范
29
4.3.5 模块定义与通信伪指令
2019/7/25
9
4.2.3 汇编语言中的表达式
• 表达式由操作数和运算符组成,在汇编时一个表达式得到 一个值。表达式分为数值表达式和地址表达式。
– 1.表达式中的常量 – 常量是在汇编时已经确定的常数值,常量可以是数据和字符。常
量表示一个固定的数值,它又分成多种形式。 – (1)常数:指由10、16、2和8进制形式表达的数值。 – (2)字符串:字符串常量是用单引号或双引号括起来的单个字
围内时,可用SHORT运算符进行说明,以保证汇编程序能为该指 令生成最短的机器码,从而提高运行效率。
2019/7/25
- 1、下载文档前请自行甄别文档内容的完整性,平台不提供额外的编辑、内容补充、找答案等附加服务。
- 2、"仅部分预览"的文档,不可在线预览部分如存在完整性等问题,可反馈申请退款(可完整预览的文档不适用该条件!)。
- 3、如文档侵犯您的权益,请联系客服反馈,我们会尽快为您处理(人工客服工作时间:9:00-18:30)。
第一讲第三章 指令系统--寻址方式回顾: 8086/8088的内部结构和寄存器,地址分段的概念,8086/8088的工作过程。
重点和纲要:指令系统--寻址方式。
有关寻址的概念;6种基本的寻址方式及有效地址的计算。
教学方法、实施步骤时间分配 教学手段 回 顾 5”×2 板书 计算机 投影仪 多媒体课件等讲 授 40” ×2 提 问 3” ×2 小 结2” ×2讲授内容:3.1 8086/8088寻址方式首先,简单讲述一下指令的一般格式:操作码 操作数 …… 操作数计算机中的指令由操作码字段和操作数字段组成。
操作码:指计算机所要执行的操作,或称为指出操作类型,是一种助记符。
操作数:指在指令执行操作的过程中所需要的操作数。
该字段除可以是操作数本身外,也可以是操作数地址或是地址的一部分,还可以是指向操作数地址的指针或其它有关操作数的信息。
寻址方式就是指令中用于说明操作数所在地址的方法,或者说是寻找操作数有效地址的方法。
8086/8088的基本寻址方式有六种。
1.立即寻址所提供的操作数直接包含在指令中。
它紧跟在操作码的后面,与操作码一起放在代码段区域中。
如图所示。
例如:MOV AX ,3000H立即数可以是8位的,也可以是16位的。
若是16位的,则存储时低位在前,高位在后。
立即寻址主要用来给寄存器或存储器赋初值。
2.直接寻址操作数地址的16位偏移量直接包含在指令中。
它与操作码—起存放在代码段区域,操作数一般在数据段区域中,它的地址为数据段寄存器DS加上这16位地址偏移量。
如图2-2所示。
例如: MOV AX,DS:[2000H];图2-2(对DS来讲可以省略成 MOV AX,[2000H],系统默认为数据段)这种寻址方法是以数据段的地址为基础,可在多达64KB的范围内寻找操作数。
8086/8088中允许段超越,即还允许操作数在以代码段、堆栈段或附加段为基准的区域中。
此时只要在指令中指明是段超越的,则16位地址偏移量可以与CS或SS或ES相加,作为操作数的地址。
MOV AX,[2000H] ;数据段MOV BX,ES:[3000H] ;段超越,操作数在附加段即绝对地址=(ES)*16+3000H3.寄存器寻址操作数包含在CPU的内部寄存器中,如寄存器AX、BX、CX、DX等。
例如:MOV DS,AXMOV AL,BH4.寄存器间接寻址操作数是在存储器中,但是,操作数地址的16位偏移量包含在以下四个寄存器SI、DI、BP、BX之一中。
可以分成两种情况:(1)以SI、DI、BX间接寻址,则通常操作数在现行数据段区域中,即数据段寄存器(DS)*16加上SI、DI、BX中的16位偏移量,为操作数的地址,例如: MOV AX, [SI] 操作数地址是:(DS)*16+(SI)(2)以寄存器BP间接寻址,则操作数在堆栈段区域中。
即堆栈段寄存器(SS)*16与BP的内容相加作为操作数的地址,例如:MOV AX,[BP] 操作数地址是:(SS)*16+(BP)若在指令中规定是段超越的,则BP的内容也可以与其它的段寄存器相加,形成操作数地址。
例如: MOV AX,DS:[BP] 操作数地址是:(DS)*16+(BP)5.变址寻址由指定的寄存器内容,加上指令中给出的8位或16位偏移量(当然要由一个段寄存器作为地址基准)作为操作数的偏移地址。
(操作数在存贮器中)可以作为寄存器变址寻址的四个寄存器是SI、DI、BX、BP。
⑴若用SI、DI和BX作为变址,则与数据段寄存器相加,形成操作数的地址即默认在数据段;⑵若用BP变址,则与堆栈段寄存器相加,形成操作数的地址即默认在堆栈段例如: MOV AX,COUNT[SI];操作数地址是:(DS)*16+(SI)+COUNT但是,只要在指令中指定是段超越的,则可以用别的段寄存器作为地址基准。
6.基址加变址寻址把BX和BP看成是基址寄存器,把SI、DI看着是变址寄存器,把一个基址寄存器(BX或BP)的内容加上一个变址寄存器(SI或DI)的内容,再加上指令中指定的8位或16位偏移量(当然要以一个段寄存器作为地址基准)作为操作数的偏移地址,如图所示。
操作数在存贮器中,其偏移地址由(基址寄存器)+(变址寄存器)+相对偏移量形成基址寄存器――BX:数据段、BP:堆栈段;变址寄存器――SI、DI。
例如:MOV AX,[BX][SI] 或 MOV AX,[BX+SI]也可放置一个相对偏移量,如COUNT 、MASK等等,用于表示相对寻址。
MOV AX,MASK[BX][SI]MOV BH,COUNT[DI][BP];MOV BH,COUNT[BP+DI]✧若用BX作为基地址,则操作数在数据段区域✧若用BP作为基地址,则操作数在堆栈段区域但若在指令中规定段是超越的,则可用其它段寄存器作为地址基准。
P.28 表2-1 段寄存器使用的基本约定习题与思考:1.假定DS=2000H,ES=2100H,SS=1500H,SI=00A0H,BX=0100H,BP=0010H,数据变量VAL 的偏移地址为0050H,请指出下列指令源操作数是什么寻址方式?其物理地址是多少?(1)MOV AX,0ABH (2)MOV AX,[100H](3)MOV AX,VAL (4)MOV BX,[SI](5)MOV AL,VAL[BX] (6)MOV CL,[BX][SI](7)MOV VAL[SI],BX (8)MOV [BP][SI],1002.已知SS=0FFA0H,SP=00B0H,先执行两条把8057H和0F79H分别进栈的PUSH指令,再执行一条POP指令,试画出堆栈区和SP内容变化的过程示意图。
(标出存储单元的地址)第二讲3.2 指令系统--数据传输、算术运算回顾:8086/8088的内部结构和寄存器,8086/8088的工作过程。
8086/8088的寻址方式及操作数地址的计算。
重点和纲要:要求学生了解指令的功能,掌握数据传送类,算术运算类指令的使用方法。
(掌握指令内涵,会用)讲授内容:3.2 8086/8088 指令系统8086/8088的指令系统可以分为以下六个功能组。
1.数据传送(Data Transter) 2.算术运算(Arithmetic)3.逻辑运算(Logic) 4.串操作(String menipulation)5.程序控制(Program Control) 6.处理器控制(Processor Control)一、数据传送指令主要介绍 MOV,XCHG、堆栈和地址传送指令。
1.数据传送MOV指令一般格式:MOV OPRD1,OPRD2MOV 是操作码,OPRD1和OPRD2分别是目的操作数和源操作数。
功能:完成数据传送具体来说,一条数据传送指令能实现:⑴CPU内部寄存器之间数据的任意传送(除了代码段寄存器CS和指令指针IP以外)。
MOV AL,BL;字节传送MOV CX,BX;字传送MOV DS,BX⑵立即数传送至CPU内部的通用寄存器组(即AX、 BX、CX、DX、BP、SP、SI、DI),MOV CL,4MOV AX,03FFHMOV SI,057BH⑶CPU内部寄存器(除了CS和IP以外)与存储器(所有寻址方式)之间的数据传送。
MOV AL,BUFFERMOV AX,[SI]MOV [DI],CXMOV SI,BLOCK[BP]MOV DS,DATA[SI+BX]MOV DEST[BP+DI],ES⑷能实现用立即数给存储单元赋值例如:MOV [2000H],25HMOV [SI],35H对于MOV 指令应注意几个问题:①存储器传送指令中,不允许对CS和IP进行操作;②两个操作数中,除立即寻址之外必须有一个为寄存器寻址方式,即两个存储器操作数之间不允许直接进行信息传送;如我们需要把地址(即段内的地址偏移量)为AREAl的存储单元的内容,传送至同一段内的地址为AREA2的存储单元中去,MOV指令不能直接完成这样的传送,但我们可以用CPU内部寄存器为桥梁来完成这样的传送:MOV AL,AREAlMOV AREA2,AL③两个段寄存器之间不能直接传送信息,也不允许用立即寻址方式为段寄存器赋初值;如:MOV AX,0;MOV DS,AX④目的操作数,不能用立即寻址方式。
2.堆栈指令(简述堆栈的概念及存取特点,如先进后出)包括入栈(PUSH)和出栈(POP)指令两类。
仅能进行字运算。
(操作数不能是立即数)⑴入栈指令PUSH一般格式:PUSH OPRD源操作数可以是CPU内部的16位通用寄存器、段寄存器(CS除外)和内存操作数(所有寻址方式)。
入栈操作对象必须是16位数。
功能:将数据压入堆栈执行步骤为:SP=SP-2;[SP]=操作数低8位;[SP+1]= 操作数高8位例如:PUSH BX执行过程为:SP=SP-1,[SP]=BH;SP=SP-1,[SP]=BL,如图2-8所示。
⑵出栈指令POP一般格式:POP OPRD功能:将数据弹出堆栈对指令执行的要求同入栈指令。
例如:POP AX 图2-8POP [BX]POP DS3.交换指令 XCHG一般格式:XCHG OPRD1,OPRD2功能:完成数据交换这是—条交换指令,把一个字节或一个字的源操作数与目的操作数相交换。
交换能在通用寄存器与累加器之间、通用寄存器之间、通用寄存器与存储器之间进行。
但段寄存器和立即数不能作为一个操作数,不能在累加器之间进行。
例如: XCHG AL,CLXCHG AX,DIXCHG BX,SIXCHG AX,BUFFERXCHG DATA[SI],DH4.累加器专用传送指令有三种,输入、输出和查表指令。
前两种又称为输入输出指令。
⑴ IN 指令一般格式:IN AL,n ; B AL←[n]IN AX,n ; W AX←[n+1][n]IN AL,DX ; B AL←[DX]IN AX,DX ; W AX←[DX+1][DX]功能:从I/O端口输入数据至AL或AX。
输入指令允许把一个字节或一个字由一个输入端口传送到AL或AX中。
若端口地址超过255时,则必须用DX保存端口地址,这样用DX作端口寻址最多可寻找64K个端口。
⑵ OUT 指令一般格式:OUT n,AL ; B AL→[n]OUT n,AX ; W AX→[n+1][n]OUT DX,AL ; B AL→[DX]OUT DX,AX ; W AX→[DX+1][DX]功能:将AL或AX的内容输出至I/O端口。
该指令将AL或AX中的内容传送到一个输出端口。
端口寻址方式与IN指令相同。
⑶ XLAT指令一般格式:XLAT ; AL=(DX)×16+(BX)+(AL))功能:完成一个字节的查表转换。