汇编语言4(顺序、分支)

合集下载

汇编语言程序设计

汇编语言程序设计

汇编语⾔程序设计第4章汇编语⾔程序设计§4.1 汇编语⾔的模式⼀、汇编语⾔源程序的⼀般模式[Name 模块名][Title 标题][定义宏][定义数据段][定义附加段][定义堆栈段]定义代码段源程序结束中括号括起的部分可以省略,可见在⼀个汇编语⾔源程序中必须要定义代码段,并且必须有源程序结束指令。

⼆、8086汇编语⾔程序的⼀个例⼦Pg90。

§4.2 语句⾏的构成汇编语⾔中的语句⼀般分为两种类型:指令性语句和指⽰性语句。

指令性语句的格式为:[标号:] 助记符 [操作数1[,操作数2]] [;注释]指⽰性语句的格式为:[名称] 助记符 [参数1,参数2,……] [;注释]标号和名称都是编程⼈员根据需要和⼀定的规则任意取的。

也可以认为汇编语⾔的语句⾏是由标记和分隔符(空格)构成。

⼀、标记1.IBM宏汇编的字符集(1)字母(2)数字符(3)特殊字符2.界符⽤于定界⼀个标记的结束或⼀个标记的开始,本⾝具有⼀定的意义。

3.常量出现在汇编语⾔源程序中的固定值称为常量。

(1)数值常量①⼆进制:以字母B结束。

②⼗进制:以字母D或⽆字母结束。

③⼋进制:以字母Q(或O)结束。

④⼗六进制:以字母H结束。

(2)字符常量指⽤单引号或双引号引起的字符或字符串。

4.标识符由程序员⾃⼰建⽴的字符序列(标号或名称)。

⼀个标识符不能超过31个字符,不能以数字开头。

5.保留字汇编语⾔中具有特殊意义的字符序列。

6.注释⼀⾏中分号以后的部分。

⽤于对⼀段或⼀⾏程序进⾏说明,便于阅读和理解。

⼆、符号具有⼀定意义的字符序列。

1.寄存器名2.变量段属性、偏移属性、类型属性3.标号段属性、偏移属性、类型属性4.常数5.其它三、表达式由操作数和运算符组合⽽成的序列。

1.操作数(1)⽴即数(2)寄存器操作数(3)存储器操作数2.运算符(1)算术运算符+、-、*、/、MOD(求余)(2)逻辑运算符AND、OR、NOT、XOR(3)关系运算符EQ、NE、LT、LE、GT、GE结果为“假”时,返回0,结果为“真”时,返回⼆进制全1。

汇编语言程序设计

汇编语言程序设计

6)组合运算符(属性修改运算符) ① PTR运算符:运算符PTR可以指定或修改存储器操作数的 类型。注意,这种修改是临时性的,仅在该语句内有效。 下面是使用PTR运算符的例子: 例10 INC BYTE PTR[BX] 该语句的目的操作数是内存单元,用寄存器作为地址指 针。如果仅仅使用[BX]来表示该操作数,则汇编该语句时 ,不能确定该存储单元是字节单元还是字单元。因此,必 须使用BYTE PTR说明它为字节操作数(若为字操作数, 则使用WORD PTR说明)。
4)分析运算符:分析运算符有:SEG、OFFSET、TYPE、 LENGTH和SIZE。 ① SEG运算符:利用SEG运算符可以得到一个标号或变量的段 基值。下面的指令将ARRAY的段基值送给DS寄存器。 例4 MOV AX,SEG ARRAY MOV DS,AX ② OFFSET运算符:利用OFFSET运算符可以得到一个标号或 变量的偏移量。下面的指令将STRING的偏移地址送给DX。 例5 MOV DX,OFFSET STRING ③ TYPE运算符:运算符TYPE的运算结果是一个数值,这个数 值与操作数类型的对应关系见表4-1。
4.1.3
汇编语言的表达式
(3)表达式。表达式是操作数常见的形式,它由常数、变量 、标号通过操作运算符连接而成。 汇编语言中有:算术运算符、逻辑运算符和关系运算符等 。 1)算术运算符:常用的有:+(加)、–(减)、*(乘)、/ (除)和MOD(模运算)等,算术运算的结果是一个数值 。 例1 MOV AX,VARX+2 表示VARX的地址加2后对应的存储字单元内容送给AX。 2)逻辑运算符:AND(逻辑“与”)、OR(逻辑“或”) 、NOT(逻辑“非”)和XOR(逻辑“异或”)。逻辑运算 用于数值表达式中对数值进行按位逻辑运算,并得到一个数 值结果。 例2 MOV AL,0FH AND 35H 表示将0FH与35H按位相与后得到05H送给AL, 这条指令 与MOV AL, 05H 等效。

单片机学习第四章汇编语言程序设计

单片机学习第四章汇编语言程序设计
整理课件
ORG START:CLR
MOV SUBB JC MOV XCH MOV NEXT: NOP SJMP END
1000H C A,60H A,61H NEXT A,60H A, 61H 60H,A
$
;0→CY
;做减法比较两数 ;若(60H)小,则转移
;交换两数
整理课件
【例4.6】将R2中的一位十六进制数转换为 ASCII码,结果仍存放于R2中。
MOV R0, #0 SJMP NEXT4 NEXT2:MOV R0,A DEC R0 NEXT4:MOV 31H,R0 SJMP $ END
;取X ;与5比较
;X<5,则转NEXT2 ; ;设10<X,Y=X十1
;与1l比较 ;x>10,则转NEXT4
;5≤X≤10,Y=0
;X<5,Y=X-1 ;存结果
MOV
@R0,A
;保存结果
SJMP $
;原地踏步
END
整理课件
【例4.2】假设两个双字节无符号数,分别存 放在R1R0和R3R2中,高字节在前,低字 节在后。编程使两数相加,用R2R1R0存放 和。 对多字节的加法,存在最高位的进位问题。 如果最高位有进位,则和的字节数要比加 数或被加数的字节数多一个。
经常用于定义一个地址表。Yi为双字节数据, 它可以为十进制或十六进制的数,也可以 为一个表达式。高位数在前,低位数在后。
整理课件
• 例如: ORG 1000H DATA:DW 3241H,1234H,78H 上述程序将对从1000H单元开始的6个单元 赋值,赋值情况如何呢? (1000H)=32H,(1001H)=41H, (1002H)=12H,(1003H)=34H, (1004H)=00H,(1005H)=78H。

汇编语言分支结构程序设计技巧

汇编语言分支结构程序设计技巧

《 编语 言程 序 设 计 》 高 等 院 校计 算 机 专 业 教 学 体 系 中的 汇 是 门重 要 的专 业 基 础 课 程 r1 汇编 语 言是 能 够 充 分 发 挥计 算 机 1。 所 有硬 件 特 性 并 能 直 接 控 制 硬 件 的 最 快 、 有 效 的语 言 。 和 计 最 它 算 机 的 硬 件 系 统 紧 密 联 系 .本 文 主 要 讨 论 8 8/0 8的 汇 编 语 0 68 8 言 。汇 编 语 言 是 结 构 化 的 『1结 构 化 编程 技 术 简 化 了程 序 实 现 , 2,

指 令 的通 用格 式是 : 件 标 号 , 件 转 移 指 令 的 功 能 是 : 果 J条 条 如 条 件 成 立 , 转 到 标 号 所 标 明 的指 令 去 执 行 ; 果 条 件 不 成 立 , 则 如 则顺序执行。 由此 可 以得 到 , 号 处 是 ” ” 标 Y 分支 , 紧跟 条件 转 移 指
这 里我 们 以这 样 的一 个 例 子 为 例 进 行 介 绍 : 已定 义 了 两个 整 数 变 量 A和 B. 编 写程 序完 成 以下 功 能 : 试 1 若 两 个 数 中 有 一 个 是 奇 数 , 将 奇 数 存 入 A 中 , 数 存 ) 则 偶
入 B中。
2 若 两个 数 均 为 奇 数 . 将 两 数 均 加 l 存 回原 变量 。 ) 则 后 3 若 两个 数 均为 偶 数 . 两 个 变 量 均 不 变 。 ) 则 首先 , 我们 对 题 意 进 行 分 析 。变 量 A 和 B的 奇偶 情 况 有 四
要 是 用条 件 转 移 指 令 来 实现 的 , 文 结 合 汇 编 语 言 中条 件 转 移 指 令 的特 点及 作 者 多年 的 教 学 经验 提 出 了设 计 分 支结 构程 序 本

单片机课件 汇编语言程序设计PPT

单片机课件 汇编语言程序设计PPT
结构如下:
4.1 概述
---- 程序头( 即定义变量和等值符号)---SCL BIT P1.2 ;定义SCL位变量 SDA BIT P1.3 ;定义SDA位变量 ByteCon DATA 30H ;定义字节变量
ByteCon ……
ORG nnnn ;CPU复位后,第一指令机器码存 放单元地址,具体值由CPU类型决定。
用到的有关寄存器,如 Acc、PSW等,即保护现场 …… ;中断服务程序实体,具体指令由程序功能决
定 POP Acc POP PSW ;恢复现场
4.1 概述
CLR TI ;清除中断标志(在51系列中,对于电平触 发的外中断INT0和 INT1、串行接收及发送中断 RI、TI 等,不自动清除,需要在中断服务结束前,通过CLR指 令清除。
例4.9 在51系列中,外部中断0的入口地址为 0003H,显然只有0000H、0001H和0002H三个单 元,刚好可以存放一条长跳转指令的机器码。
4.1 概述
----- 主程序 ----ORG yyyy ;其中yyyy就是主程序代码存放区 的首地址,如0100H Main: MOV SP,#5FH ;初始化有关寄存器,如 设置SP、选择工作寄存器组。
际问题处理程序编写能力。
4.1 概述
4.1 概述 程序设计:为了解决某一个问题,将所设计应用
系统(单片机类型)的指令按一定顺序组合在一起。即用 计算机所能接受的语言把解决问题的步骤描述出来。
单片机汇编源程序结构与通用微机汇编源程序结构 略有不同,原因是:
1、一般没有可以直接利用的监控程序,所有程 序均要自己编写。
转移。(程序走向只有一条路径。)
例4.11 将两个半字节数组合成一个字节数。 设内部RAM中40H、41H单元分别存放着8位二进制

汇编语言程序设计的基本方法

汇编语言程序设计的基本方法

01
例2 编写程序,计算(W-(X*Y+Z-100))/W,其中W、X、Y、Z均为16位带符号数,计算结果的商存入AX,余数存入DX。
02
例3 把非压缩十进制数DAT1转换为压缩十进制数
例2编写程序,计算(W-(X*Y+Z-100))/W,其中W、X、Y、Z均为16位带符号数,计算结果的商存入AX,余数存入DX。
通常,编制一个汇编语言源程序应按如下步骤进行:
1
明确任务,确定算法。
2
绘制流程图(包括确定内存单元和分配寄存器)。
3
根据流程图编写汇编语言程序。
4
上机调试程序。
5
程序的基本结构有四种:顺序结构、分支结构、循环结构和子程序结构。
6
5.6 汇编语言程序设计的基本方法
5.6.1 顺序程序设计
顺序结构也称线性结构,其特点是其中的语句或结构被连续执行。 顺序程序是最简单的,也是最基本的一种程序结构。这种结构的程序从开始到结尾一直是顺序执行的,中途没有任何分支。从这种结构的流程图来看,除了有一个起始框,一个终止框外,就是若干执行框,没有判断框。指令指针IP值线形增加,IP=IP+1
条件
N

例4用比较指令和条件转移指令实现两路分支的程序段。
两路分支程序设计
例4用比较指令和条件转移指令实现两路分支的程序段。 … MOV AX,M ;假定M和N为有符号数 MOV BX,N CMP AX,BX ;比较 M和N的大小,影响标志位,准备条件 JG NEXT ;M>N时转移,注意若M、N为无符号数时用JA指令 …… ;分支程序2 JMP DONE NEXT: …… ;分支程序1 …… DONE:RET
X+20 (X≥0)

第4章 汇编 语言程序设计

第4章  汇编 语言程序设计
14
汇编时,遇到“ 就停止“翻译” 因此, 汇编时,遇到“;” 就停止“翻译”。因此,注释字 段不会产生机器代码。 段不会产生机器代码。 4.1.3 伪指令 在汇编语言源程序中应有向汇编程序发出的指示信息, 在汇编语言源程序中应有向汇编程序发出的指示信息, 向汇编程序发出的指示信息 告诉它如何完成汇编工作,这是通过伪指令来实现。 伪指令来实现 告诉它如何完成汇编工作,这是通过伪指令来实现。 伪指令不属于指令系统中的汇编语言指令,它是程序员 伪指令不属于指令系统中的汇编语言指令, 发给汇编程序的命令,也称为汇编程序控制命令。 发给汇编程序的命令,也称为汇编程序控制命令。 命令 汇编程序控制命令 只有在汇编前的源程序中才有伪指令。 “伪”体现在 只有在汇编前的源程序中才有伪指令。 汇编后,伪指令没有相应的机器代码产生。 汇编后,伪指令没有相应的机器代码产生。 没有相应的机器代码产生 伪指令具有控制汇编程序的输入/输出、 伪指令具有控制汇编程序的输入/输出、定义数据和符 号、条件汇编、分配存储空间等功能。 条件汇编、分配存储空间等功能。
6
经过十几年努力,C51已成为单片机的实用高级编程语言。 经过十几年努力,C51已成为单片机的实用高级编程语言。 已成为单片机的实用高级编程语言 尽管目前已有不少设计人员使用C51来进行程序开发, 尽管目前已有不少设计人员使用C51来进行程序开发,但在 C51来进行程序开发 对程序的空间和时间要求较高的场合,汇编语言仍必不可少 程序的空间和时间要求较高的场合, 空间 要求较高的场合 。 在这种场合下,可使用C语言和汇编语言混合编程。 在这种场合下,可使用C语言和汇编语言混合编程。在很多 需要直接控制硬件且对实时性要求较高的场合,则更是非用 需要直接控制硬件且对实时性要求较高的场合, 汇编语言不可。 汇编语言不可。 掌握汇编语言并能进行程序设计, 掌握汇编语言并能进行程序设计,是学习和掌握单片机程 序设计的基本功之一。 序设计的基本功之一。 基本功之一 4.1.2 汇编语言语句和格式

汇编教程汇编指令详解

汇编教程汇编指令详解

汇编教程汇编指令详解
汇编语言可以说是机器语言的一种直观形式,是与硬件直接相关的低
级程序设计语言。

它是一种以简洁的汇编指令来表达操作码机器指令的程
序设计语言,汇编语言的指令代码一般比机器语言的指令代码要短,是编
写高效、可移植的机器级程序的理想语言。

汇编语言的基本构成:
(1)指令集:汇编语言的指令集是机器的最基本和最重要的组成部分,也是机器的指令集,描述了机器所做的操作。

(2)操作数:汇编语言的指令集中涉及到的操作数有多种,比如寄
存器操作数、立即数、内存操作数等。

(3)运算和转移指令:汇编语言中的运算和转移指令包括算术运算
指令、比较指令、逻辑运算指令、移位指令等,它们是机器执行的基本操作。

(4)转移指令:汇编语言中的转移指令可以改变机器指令的执行顺序,并实现分支程序设计。

(5)I/O指令:汇编语言中的I/O指令可以实现与外部设备的通信,获取外部设备提供的数据。

(6)汇编指令:汇编指令用于移植各种汇编程序到不同的处理器上,从而实现程序的机器无关性。

一、MOV指令:
MOV指令用于把操作数的值赋给另一个操作数。

第四章-汇编语言程序的设计

第四章-汇编语言程序的设计

第四章汇编语言程序设计本章的汇编语言程序设计的主要容有:汇编语言程序设计概述、汇编语言程序的结构形式、汇编语言的伪指令。

(一个单片机应用系统和其它计算机系统一样,在完成一项具体工作的时候,它要按照一定的次序,去执行操作,这些操作实际上就是由设计人员,以单片机能够接受的指令编制的程序,那么无论计算机也好,单片机也好,实际上编制程序的过程,就是用计算机来反映设计者的编程思想,那么这一章中,我们将向大家介绍怎样使用单片机指令系统来编制一些应用程序。

在介绍之前,我们还是来学习汇编语言的一些基础知识)4.1 汇编语言程序设计概述1、计算机的汇编语言以助记符表示的指令,每一条指令就是汇编语言的一条语句。

(汇编语言程序设计实际上就是使用汇编指令来编写计算机程序。

汇编语言的语句有严格的格式要求)2、汇编语言的语句格式MCS-51汇编语言的语句格式表示如下:[<标号>]: <操作码> [<操作数>]; [<注释>]标号:指令的符号地址,有了标号,程序中的其它语句才能访问该语句。

①标号是由1~8个ASCII字符组成,但头一个字符必须是字母,其余字符可以是字母、数字或其它特定字符。

②不能使用汇编语言已经定义了的符号作为标号,如指令助记符、伪指令记忆符以及寄存器的符号名称等。

(同一个标号在程序中只能定义一次,不能重复定义;一条语句可以有标号,也可以没有标号,所以是否有标号,取决于程序中是否需要访问该语句。

)操作码:规定语句执行的操作容,操作码是以指令助记符表示的,是汇编指令格式中唯一不能空缺的部分。

操作数:给指令的操作提供数据或地址。

注释:是对语句或程序段的解释说明。

(在单片机中,这四个部分怎么加以区分呢?使用分界符)分界符(分隔符):用于把语句格式中的各部分隔开,以便于编译程序区分不同的指令段。

冒号(:)用于标号之后空格()用于操作码和操作数之间逗号(,)用于操作数之间,分割两个以上的操作数分号(;)用于注释之前。

汇编语言的名词解释

汇编语言的名词解释

汇编语言的名词解释汇编语言是一种低级编程语言,用于编写计算机程序。

它是一种符号化的机器语言表示形式,通过汇编程序翻译成机器指令,以便能够被计算机执行。

在汇编语言中,使用各种名词来描述不同的概念和操作。

1. 汇编语言 (Assembly language)汇编语言是一种使用助记符(Mnemonics)和符号(Symbol)来代替二进制代码的编程语言。

它直接对应于计算机的指令集体系结构,可以通过助记符和符号来描述计算机的操作、寄存器、内存地址等信息。

2. 指令 (Instruction)指令是汇编语言中最基本的单位,用于指示计算机执行某种操作。

指令通常以助记符的形式表示,例如MOV、ADD、JMP等。

一个指令包含操作码(Opcode)和操作数(Operand),操作码表示需要执行的操作,操作数则提供了操作所需的数据或地址。

3. 寄存器 (Register)寄存器是用于存储和操作数据的高速内存单元。

汇编语言使用寄存器来进行计算、传输数据和控制程序流程等操作。

通常,寄存器具有特定的名称和功能,例如AX、BX、CX等通用寄存器,以及SP、BP、SI、DI等特殊用途寄存器。

4. 内存地址 (Memory Address)内存地址指示了计算机内存中存储数据的位置。

在汇编语言中,使用内存地址来读取和存储数据。

内存地址可以通过直接给出地址值或使用标号(Label)来表示。

5. 标志位 (Flag)标志位是用于记录计算机运算过程中的条件结果的特殊寄存器。

在汇编语言中,标志位可用于控制程序的跳转、判断条件和处理中断等操作。

6. 宏指令 (Macro)宏指令是一种能够扩展和简化程序的代码片段。

它可以在汇编语言中定义和调用,类似于高级编程语言中的函数或宏定义。

宏指令能够减少代码重复和提高程序的可维护性。

7. 伪指令 (Pseudo-Instruction)伪指令是汇编语言中的一种特殊指令,用于给汇编程序提供附加的信息和指导。

汇编语言程序汇总

汇编语言程序汇总

例:延时程序,多重循环实现软件延时。 DELAY:MOV DX,3FFH TIME:MOV AX,0FFFFH TIME1:DEC AX NOP JNE TIME1 DEC DX JNE TIME RET
内循环控制变量AX,初值=FFFFH 外循环控制变量DX,初值=3FFH
五、字符串处理程序
字符:ASCII码 说明:
MOV PRODUCT[BX+2], AX
MOV PRODUCT[BX+4], DX
PUSHF
; 保存后一次相加的进位标志
MOV AX, MULNUM[BX+2] ; A→AX
MUL DI
; A×C
POPF;标志出栈
ADC DX,0 ADC AX, PRODUCT[BX+4] ; 与部分积4的相应部分相加 ADC DX, 0 MOV PRODUCT[BX+4], AX MOV PRODUCT[BX+6], DX RET START ENDP CODE ENDS END BEGIN
START PROC FAR
; 定义子程序
ASSUME CS:CODE,DS:DATA,SS:STACK
BEGIN: PUSH DS
;(4)置子程序返回地址
MOV AX,0
PUSH AX
MOV AX,DATA
;置DS
MOV DS,AX
MOV AX,STACK
;置SS
MOV SS,AX
MOV AX,TOP
mov dl,0 ;串长度初始DL=0
mov al,cr ;结束符→AL
again:scasb
;搜索串
je done;找到转DONE,停止搜索
inc dl

第4章 汇编语言程序设计

第4章 汇编语言程序设计

例: 三字节无符号数相加,其中被加数在内部RAM 的50H、51H和52H 单元中;加数在内部RAM的53H、 54H和55H单元中;要求把相加之和存放在50H、 51H和52H单元中,进位存放在位寻址区的00H位中。
内部RAM
50H 51H 52H
高字节 低字节
53H 54H 55H
R1→55H
结 束
常用程序结构:
顺序程序、分支程序、循环程序。
4-3
顺序程序
顺序程序又称简单程序,程序走向只有一条路径。 例:双字节求补程序(设数据在R4R5中): 开 始 CLR C MOV A,R5 ;取低字节 处 理 CPL A ADD A,#01H ;低字节变补 处 理 MOV R5,A MOV A, R4 ;取高字节 处 理 CPL A ADDC A,#00H ;高字节变补 结 束 MOV R4,A
片内 RAM 42H 0 十 41H 0 个 40H 十 个
4 -- 4
分支程序(参见书P49-57)
分支程序就是在程序执行过程中要判 断某些条件,当条件成立后程序转移到不 同的功能处运行。在MCS-51单片机中条件 转移指令都可以用在分支程序中。 (复习、参见书P38---39) (1)测试条件符合转移,如: JZ、JNB …等
汇编的主要任务:
1)确定程序中每条汇编语言指令的指令机器码。 2)确定每条指令在存储器中的存放地址。 3)提供错误信息。 4)提供目标执行文件(*.OBJ/*.HEX)和 列表文件(*.LST)。
一、汇编语言指令类型:
1. 机器指令: 指令系统中的全部指令,每条指令有对应的机器代码。 2. 伪指令: 汇编控制指令,仅提供汇编信息,没有指令代码。
在源程序中只能有一条END指令

第4章 汇编语言程序设计知识

第4章 汇编语言程序设计知识
9
操作码
操作码是必不可少的。 它用一组字母符号表示指令的操作码。在 89C51中,由89C51的指令助记符组成。

10
操作数
汇编语言指令可能要求或不要求操作数,所以这一字段可能 有也可能没有。 若有两个操作数,操作数之间用逗号“,”分开。 操作数包括的内容有: (1)工作寄存器:由PSW.3和PSW.4规定的当前工作寄存器 区中的R0~R7。 (2)特殊功能寄存器:21个SFR的名字。 (3)标号名:赋值标号—由汇编指令EQU等赋值的标号;指 令标号—指令标号指示的指令的第一字节地址是该标号的值。 (4)常数:可用二进制(B)、十进制、十六进制(H),若 常数以字符开头,前面加0。 (5)$:用来表示程序计数器的当前值。 (6)表达式:汇编时,计算出表达式的值填入目标码。
程序中含有转移指令; 体现了计算机执行程序时的分析判断能力。
21
MCS-51中,条件转移指令共有13条
分为累加器A判零条件转移、比较条件转移、减1条件转移和位控制 条件转移等四类。
1. A判零 2. 比较
jz rel cjne
jnz rel opr1,opr2,rel (A Rn @Ri) (#data
41
二、机ቤተ መጻሕፍቲ ባይዱ汇编

机器汇编是在计算机上使用交叉汇编程序进行源程 序的汇编。汇编工作由机器自动完成,最后得到以 机器码表示的目标程序。
42
三、反汇编

将二进制机器语言程序翻译成汇编语言程序的过程称反汇编。

汇编和反汇编的过程如图4-3所示。
汇编(汇编程序)
源程序 (汇编语言)
反汇编(汇编程序)
目标码 (机器语言)
N
A > 0? N A← 1 存结果

汇编语言4

汇编语言4
0
高位
dest
低位
CF
图3-4 逻辑右移操作示意图
例3-35:分析以下程序段。
• MOV BX ,24H ;(BX)= 36 = 00100100B • MOV CL ,2 • SHR BX ,CL ;将BX内容右移2位, (BX)= 00001001B,CF=0 • 执行程序段以后,(BX)= 09H = 9,相当于除以2的2 次方。 • 由此可见,逻辑右移指令可以方便地实现操作数除运算 (n为移位次数)。不过在使用中要注意操作数应该为无 符号数,否则会得出错误结果。
例3-27:
MOV AL ,56H ;(AL)= 01010110B
NOT AL ;(AL)= 10101001B = 0A9H • 说明:NOT指令是单操作数指令,该操作数可以是立即数以 外的任何寻址方式。NOT指令不影响标志位。
2.逻辑与指令AND
• 指令格式:AND dest , src • 功能:将目的操作数和源操作数按位“与”,结果存入目的地 址中。即dest (dest)∧(src) 。 • “与”运算的规则为:1∧1=1,1∧0=0,0∧1=0,0∧0=0。 • 该指令可以屏蔽操作数中的某些位,使其余位保持不变。要屏 蔽的位与0相“与”,不变的位与1相“与”的左移和右移能够实现对数据乘以2的 整数次幂和除以2的整数次幂。 • MOV AL,64H • MOV CL,2 • SHL AL,CL;实现对64H左移2位,得到结果 AL=90H • 左移,可能出现溢出,造成错误。
算术移位的左移和右移实现乘除
• 算术移位的左移和右移能够实现对数据乘以2的 整数次幂和除以2的整数次幂。 • MOV AL,64H • MOV CL,2 • SHL AL,CL;实现对64H左移2位,得到结果 AL=90H • 左移,可能出现溢出,造成错误。

汇编语言(四)分支结构程序设计

汇编语言(四)分支结构程序设计

汇编语言(四)分支结构程序设计分支结构是计算机程序设计中常用的一种控制结构,它根据一些条件的真假决定程序的执行路径。

在汇编语言中,我们可以使用条件分支指令来实现分支结构的程序设计。

常用的条件分支指令有以下几种:1.无条件跳转指令(JMP):该指令用于无条件跳转到指定的地址。

例如,JMPLABEL指令会跳转到LABEL标记的位置。

2.条件跳转指令:根据一些条件的真假决定是否跳转到指定的地址。

常用的条件跳转指令有以下几种:-跳转指令(JZ、JNZ):根据零标志位(ZF)的状态来判断是否跳转。

如果ZF为1,则跳转;如果ZF为0,则不跳转。

-跳转指令(JC、JNC):根据进位标志位(CF)的状态来判断是否跳转。

如果CF为1,则跳转;如果CF为0,则不跳转。

-跳转指令(JS、JNS):根据符号标志位(SF)的状态来判断是否跳转。

如果SF为1,则跳转;如果SF为0,则不跳转。

-跳转指令(JO、JNO):根据溢出标志位(OF)的状态来判断是否跳转。

如果OF为1,则跳转;如果OF为0,则不跳转。

-跳转指令(JP、JNP):根据奇偶标志位(PF)的状态来判断是否跳转。

如果PF为1,则跳转;如果PF为0,则不跳转。

-跳转指令(JA、JNA):根据无符号数比较结果来判断是否跳转。

如果无符号数比较结果为大于,则跳转;如果无符号数比较结果为小于或等于,则不跳转。

-跳转指令(JB、JNB):根据无符号数比较结果来判断是否跳转。

如果无符号数比较结果为小于,则跳转;如果无符号数比较结果为大于或等于,则不跳转。

-跳转指令(JAE、JNAE):根据无符号数比较结果来判断是否跳转。

如果无符号数比较结果为大于或等于,则跳转;如果无符号数比较结果为小于,则不跳转。

-跳转指令(JBE、JNBE):根据无符号数比较结果来判断是否跳转。

如果无符号数比较结果为小于或等于,则跳转;如果无符号数比较结果为大于,则不跳转。

-跳转指令(JE、JNE):根据有符号数比较结果来判断是否跳转。

汇编语言程序

汇编语言程序

方法三:采用同#0FH、#0F0H相与的方法分离 高低4位,将两个BCD数分开。 ORG 1000H MOV A,20H ANL A,#0FH ORL A,#30H MOV 22H,A MOV A,20H ANL A,#0F0H SWAP A ORL A,#30H MOV 21H,A;9条指令,17个字节,9个机 器周期;
第五章 汇编语言程序设计 1 程序设计方法 2 顺序程序 3 4 5 6 分支程序 循环程序 子程序 位操作程序
1、本章教学内容: (1)汇编应用概述 (2)简单程序设计 (3)分支程序 (4)循环程序 (5)查表程序 (6)子程序的设计及其调用
(7)位操作程序
2、本章基本要求 (1)掌握简单程序设计 (2)掌握分支和散转程序设计 (3)理解循环程序 (4)掌握简单查表程序 (5)掌握子程序的设计、位操作
程序
5-1-2 汇编语言程序设计步骤
一、 分析问题,建立数学模型。 二、确定算法:对待定问题求解步骤的一种描 述,是指令的有限集合,算法有五个特征: 有穷性、确定性、可行性、输入、输出 开始 三、制定程序流程图: 表示程序结构和程序功能
?
N
Y
1
四、编制源程序 1.确定数据结构:合理分配存储器单元和了 解I/O接口地址。 2.按功能设计,明确各程序之间关系。 3.用注释行说明程序。 生成一个ASCII码文件,扩展名为“.ASM”。
方法2 相对地址表PRGTBL:DB PRGi-PRGTBL 决定地址表长加分支处理程序长小于256B. 方法3:跳转表+散转指令 例 5 - 1 0 1 2 8 路 分 支 程 序 。 功 能 : 根 据 R3 的 值 (00H~7FH)转到128个目的地址。 参考程序:
JMPl28:MOV A,R3 RL A ;(A)×2 MOV DPTR,#PRGTBL ;散转表首址 JMP @A+DPTR ;散转 PRGTBL:AJMP ROUT00 AJMP ROUT01 … AJMP ROUT7F ;128个AJMP指令占 RORT00: … ROUT01 : … 注意:通过AJMP跳到各分支,限制分支程序入口 RORTi必须于对应AJMP指令在同一2KB范围。

第4章-汇编语言程序设计教案

第4章-汇编语言程序设计教案

第四章教学实施计划3课堂教学实施计划第 8 课教学过程设计:复习 0 分钟;授新课 100 分钟讨论 0 分钟;其它 0 分钟授课类型(请打√):理论课√讨论课□实验课□习题课□其它□教学方式(请打√):讲授√讨论□示教□指导□其它□教学手段(请打√):多媒体√模型□实物□挂图□音像□其它□4.1 汇编语言程序设计概述程序实际上是一系列计算机指令的有序集合。

我们把利用计算机的指令系统来合理地编写出解决某个问题的程序的过程,称为程序设计。

程序设计是单片机应用系统设计的重要组成部分,单片机的全部动作都是在程序的控制下进行的。

随着芯片技术的发展,很多标准的或功能型的硬件电路都集成到了芯片中,所以,软件设计在单片机应用系统开发中占的比重越来越大。

一、汇编语言和高级语言汇编语言:用助记符表示的指令称为汇编语言,用汇编语言编写的程序称为汇编语言源程序汇编语言也是面向机器的,它仍是一种低级语言。

汇编语言离不开具体计算机的硬件,与硬件紧密相关。

高级语言:高级语言不受具体“硬件”的限制,具有通用性强,直观、易懂、易学,可读性好等优点。

多数的51单片机用户使用C语言来进行程序设计。

C语言已经成为人们公认的高级语言中高效、简洁而又贴近51单片机硬件的编程语言。

二、汇编语言的特点•助记符指令和机器指令一一对应,所以用汇编语言编写的程序效率高,占用存储空间小,运行速度快,因此汇编语言能编写出最优化的程序。

•使用汇编语言编程比使用高级语言困难,因为汇编语言是面向计算机的,汇编语言的程序设计人员必须对计算机硬件有相当深入的了解。

•汇编语言能直接访问存储器及接口电路,也能处理中断,因此汇编语言程序能够直接管理和控制硬件设备。

•汇编语言缺乏通用性,程序不易移植,各种计算机都有自己的汇编语言,不同计算机的汇编语言之间不能通用。

三、汇编语言的语句格式•指令语句:每一条指令语句在汇编时都产生一个指令代码(也称机器代码),执行该指令代码对应着机器的一种操作。

第4章单片机汇编语言程序设计

第4章单片机汇编语言程序设计
A←X
Y A=0? N A>0? N A←-1 Y N A←X
Y
A=0? N R1←-1
A←1
A>0? Y R1←1 存数
存数
2012-6-5 电气与自动化学院 18
第四章汇编语言程序设计
§2 MCS-51单片机汇编语言设计 2、分支程序设计
程序:
ORG 2000H VAR DATA 40H FUN DATA 41H START:MOV A,VAR JZ SAVE JNB ACC.7,ZHENG MOV A,#0FFH SJMP SAVE ZHENG:MOV A,#01H SAVE: MOV FUN,A SJMP $ END
第四章汇编语言程序设计 第四章汇编语言程序设计 本章重点: §4.1 汇编语言程序设计基础
4.1.3 伪指令
§4.2 MCS-51汇编语言程序设计
4.2.1 顺序结构程序设计 4.2.2分支结构程序设计 4.2.3循环结构程序设计 4.2.4查表程序设计 4.2.5 子程序设计
§习题分析及解答
第四章汇编语言程序设计 4.1.3 伪指令
2012-6-5 电气与自动化学院 9
第四章汇编语言程序设计
§2 MCS-51单片机汇编语言设计 1、顺序结构程序设计
2012-6-5
例4-3:将两个三字节无符号数相加,其中一个加数在内部RAM的 32H、31H和30H单元;另一个加数在内部RAM的35H、34H和33H单 元,要求相加后的和存入32H、31H和30H单元,进位存入位寻址区 的20H单元中 程序: ORG 2000H CLR C MOV @R0,A MOV R0,#32H MOV R1,#35H DEC R0 MOV A,@R0 DEC R1 ADD A,@R1 MOV A,@R0 MOV @R0,A ADDC A,@R1 DEC R0 MOV @R0,A DEC R1 MOV A,@R0 MOV 20H,C ADDC A,@R1 SJMP $ END

第四章 汇编语言程序设计基础

第四章  汇编语言程序设计基础

4.2.2 分支程序的设计方法 ★条件控制 ★逻辑尺控制 ★地址跳转表控制
1. 条件控制——利用比较和条件转移指令实现分支,是最常用的 程序设计方法。
பைடு நூலகம்
例如,求解函数:
练习题2. 编写程序,比较两个字符串STRING1和STRING2所 含字符是否完全相同,若相同则显示“MATCH”,若不同则显示 “NO MATCH”。 答案: datarea segment string1 db ‘asfioa’ ;定义字符串STRING1 string2 db ‘xcviyoaf’ ;定义字符串STRING2 mess1 db ‘MATCH’,’$’ ;定义显示字串“MATCH” mess2 db ‘NO MATCH’,’$’ ;定义显示字串“NO MATCH” datarea ends prognam segment main proc far assume cs:prognam,ds:datarea start: push ds ;将ds:00入栈 sub ax,ax push ax mov ax,datarea ;装填数据段及附加段 mov ds,ax mov es,ax
程序流程图
mov ch,4 rotate: mov cl, 4 rol bx,cl mov al,bl and al,0fh add al,30h ;’0’-’9’ ASCII 30H-39H cmp al,3ah jl printit add al,7h ;’A’-’F’ ASCII 41H-46H printit: mov dl,al mov ah,2 int 21h dec ch jnz rotate
例4.3 将首地址为A的N字数组按照从小到大的次序整序(气 泡算法,多重循环) A dw 32,85,16,15, 8
  1. 1、下载文档前请自行甄别文档内容的完整性,平台不提供额外的编辑、内容补充、找答案等附加服务。
  2. 2、"仅部分预览"的文档,不可在线预览部分如存在完整性等问题,可反馈申请退款(可完整预览的文档不适用该条件!)。
  3. 3、如文档侵犯您的权益,请联系客服反馈,我们会尽快为您处理(人工客服工作时间:9:00-18:30)。

qvar
.data dq 1234567887654321h .code mov al,byte ptr qvar[6] mov byte ptr qvar[7],al mov al,byte ptr qvar[5] mov byte ptr qvar[6],al mov al,byte ptr qvar[4] mov byte ptr qvar[5],al mov al,byte ptr qvar[3] mov byte ptr qvar[4],al
➢ 转移指令Jcc和JMP实现分支控制;还可以 采用MASM 6.x提供的条件控制伪指令实现
单分支:求绝对值等 双分支:例4.3等 多分支:例4.4等
第4章
单分支程序设计
➢条件成立跳转,否 则顺序执行分支语 句体;注意选择正 确的条件转移指令 和转移目标地址
;计算AX的绝对值
例题 求绝对值
Good cmp ax,0
第4章
双分支程序设计
条件成立跳转执行第 2个分支语句体,否 则顺序执行第1个分 支语句体。注意第1 个分支体后一定要有 一个JMP指令跳到第 2个分支体后
例题 显示BX最高位
对比
shl bx,1 ;BX最高位移入CF
jc one
;CF=1,即最高位为1,转移
mov dl,’0’
;CF=0,即最高位为0,DL←’0’
;是否为大写条A~件Z控制循环 利用标志退出
dw disp5,disp6,disp7,disp8 ;取得各个标号的偏移地址
此处等同于 offset disp1
例4.4 代码段-2/3
start1: mov dx,offset msg ;提示输入数字
mov ah,9
int 21h
mov ah,1
;等待按键
int 21h
cmp al,'1' ;数字 < 1?
第4章
➢ 中国有句古话:
“凡事预则立,不预则废”
第4章
程序结构
指令系统
汇编语言 程序
程序格式
第4章
Байду номын сангаас
教学重点
综合应用第2章指令系统和第 3章伪指令与指令格式,第4 章从程序结构角度展开程序 设计,重点掌握: ✓分支结构程序设计 ✓循环结构程序设计 ✓子程序结构程序设计
第4章
4.1 顺序程序设计
例4.2-1/2
图示
mov al,byte ptr qvar[2] mov byte ptr qvar[3],al mov al,byte ptr qvar[1] mov byte ptr qvar[2],al mov al,byte ptr qvar[0] mov byte ptr qvar[1],al mov byte ptr qvar[0],0
➢ 尝试:计算1~100数字之和,并将结果存入字 变量SUM中。(用顺序或分支结构能实现吗?
有没有其它方法呢?)★ ★ ★
第4章
4.3 循环程序设计
➢ 循环结构一般是根据某一条件判断为 真或假来确定是否重复执行循环体
➢ 循环指令和转移指令可以实现循环控 制;还可以采用MASM 6.x提供的循环 控制伪指令实现
start2: mov ah,9
int 21h .exit 0 disp1: mov dx,offset msg1
;处理程序1
jmp start2 ...
对应修改为 ret
第4章
练习一
➢ 例题4.2如果要求算术右移8位,如何修改程 序?
➢ 编写一个程序,把从键盘输入的一个小写字 母用大写字母显示出来。
第4章
多分支程序设计
图示
➢多个条件对应各自的分支语句体,哪个条 件成立就转入相应分支体执行。多分支可以 化解为双分支或单分支结构的组合,例如:
or ah,ah
;等效于cmp ah,0
jz function0 dec ah jz function1 dec ah jz function2
;ah=0,转向function0 ;等效于cmp ah,1 ;ah=1,转向function1 ;等效于cmp ah,2 ;ah=2,转向function2
双分支程序改为单分支程序
例题 显示BX最高位
mov dl,’0’ ;DL←’0’ shl bx,1 ;BX最高位移入CF jnc two ;CF=0,最高位为0,转移 mov dl,’1’ ;CF=1,最高位为1,DL←’1’ two: mov ah,2 int 21h ;显示
编写分支程序,需留心分支的开始和结束
hex db 0bh ;任意设定了一个待转换的一位16进制数
例题 代码转换-2/2
.code
.startup
mov bx,offset ASCII ;BX指向ASCII码表
mov al,hex
;AL取得一位16进制数,正是ASCII码表中位移
and al,0fh ;只有低4位是有效的,高4位清0
xlat
计数控制循环 循环次数固定
.startup
xor ax,ax ;被加数AX清0
mov cx,100
add ax,cx
;从100,99,...,2,1倒序累加
loop again
mov sum,ax ;将累加和送入指定单元
.exit 0
end
习题4.16-1/2
;用二进制显示从键盘输入的一个字符的ASCII码
➢ 顺序程序完全按指令书写的前后顺序执 行每一条指令,是最基本、最常见的程 序结构
例4.1 计算 例4.2 移位 例题 代码转换
.model small .stack .data X dw 5 Y dw 6 Z dw 7 W dw ?
例4.1
.code .startup mov ax,X add ax,Y add ax,Z mov W,ax .exit 0 end
jb start1
cmp al,'8' ;数字 > 8?
ja start1
and ax,000fh ;将ASCII码转换成数字
例4.4 代码段-3/3
dec ax
shl ax,1 ;等效于add ax,ax
mov bx,ax jmp table[bx]
可以改为 call table[bx]
;(段内)间接转移:IP←[table+bx]
mov dl,0 ;MOV指令不改变CF
adc dl,30h ;DL←0+30H+CF
;CF若是0,则DL←'0';若是1,则DL←'1'
mov ah,2 int 21h ;显示 loop again
计数控制循环 循环次数固定
;CX减1,如果CX未减至0,则循环
.startup
例4.6
mov ax,wordX ;测试目标送AX
...
例4.4 数据段-1/3 .data
msg db 'Input number(1~8):',0dh,0ah,'$' msg1 db 'Chapter 1 : ...',0dh,0ah,'$' msg2 db 'Chapter 2 : ...',0dh,0ah,'$‘
... msg8 db 'Chapter 8 : ... ',0dh,0ah,'$' table dw disp1,disp2,disp3,disp4
第4章
地址表形成多分支
➢ 需要在数据段事先安排一个按顺序排 列的转移地址表
➢ 输入的数字作为偏移量。因为只有2个 字节16位偏移地址,所以偏移量需要 乘2
➢ 关键是要理解间接寻址方式JMP指令
Table db disp1, disp2, disp3, disp4, ...
地址表 分支1地址 分支2地址
mov cx,16 ;循环计数器置初值
mov dl,-1 ;计位器置初值
again: inc dl
test ax,1
ror ax,1
;循环指令不影响ZF
loope again
;CX≠0且ZF=jmj1eom(vp 测nbdoyo试ttnfee位oYu,为nddl0),定继最,续计满大循数足环控循条制环件循次退环数出固
;换码:AL←DS:[BX+AL]
mov dl,al ;入口参数:DL←AL
mov ah,2 ;02号DOS功能调用
int 21h .exit 0 end
;显示一个ASCII码字符
第4章
4.2 分支程序设计
➢ 分支程序根据条件是真或假决定执行与否 ➢ 判断的条件是各种指令,如CMP、TEST等
执行后形成的状态标志
jmp two ;一定要跳过另一个分支体
one: mov dl,’1’ ;DL←’1’
two: mov ah,2
int 21h ;显示
双分支程序改为单分支程序
例题 显示BX最高位
对比
shl bx,1 ;BX最高位移入CF jnc one ;CF=0,即最高位为0,转移 mov dl,’1’ ;CF=1,即最高位为1,DL←’1’ jmp two ;一定要跳过另一个分支体 one: mov dl,’0’ ;DL←’0’ two: mov ah,2 int 21h ;显示
例4.3 判断有无实根-1/2
.startup mov al,_b imul al mov bx,ax ;BX中为b2 mov al,_a imul _c mov cx,4 imul cx ;AX中为4ac(DX无有效数据)
例4.3 判断有无实根-2/2
cmp bx,ax ;比较二者大小 jge yes ;条件满足? mov tag,0 ;第一分支体:条件不满足,tag←0 jmp done ;跳过第二个分支体 yes: mov tag,1 ;第二分支体:条件满足,tag←1 done: .exit 0
相关文档
最新文档