微机计算机原理第六版第三章,微机计算机原理与应用课件-第3章.ppt

微机计算机原理与应用课件-第3章

程序如下: DATA SEGMENT ADDR DW X1, X2 RESULT DW DATA ENDS CODE SEGMENT ASSUME CS: CODE, DS: DATA START: MOV AX, DATA MOV DS, AX MOV AX, ADDR ADD AX, ADDR+2 MOV RESULT, AX MOV AH, 4CH INT 21H CODE ENDS END START 当X1=1C84H, Y=2F5BH时,运行结果为: X1=1C84H, X2=2F5BH RESULTS=4BDFH 2.分支程序 计算机可根据不同条件进行逻辑判断,从而选择不同的程序流向。程序的流向是由CS和IP(EIP)值决定的,当程序的转移仅在同一段内进行时,只需修改偏移地址IP(EIP)的值;如果程序的转移是在不同段之间进行的,则段基址CS和偏移地址IP(EIP)值均需要修改。 1.分支程序的结构形式 分支程序结构有两种形式:双分支结构和多分支结构。 (1)双分支结构 双分支结构的程序流程如图 这种结构根据条件满足或不满足可分别执行 两种分支程序段。条件满足时执行分支程序 段2,条件不满足时则执行分支程序段1。 (2)多分支结构 多分支结构的程序流程如图所示。   多分支结构可以有多个分支,适用于有多种条件的情况下,根据不同的条件进行不同的处理。多分支结构也称为CASE结构。 无论是双分支结构还是多分支结构,其共同特点是:在某一种确定的条件下,只能执行一个分支程序段,而程序的分支要靠条件转移指令来实现。 2.分支程序设计 分支程序设计要领如下。 ① 首先根据处理的问题用比较、测试、算术运算、逻辑运算等方式,使标志寄存器产生相应的标志位。例如,比较两个单元地址的高低、两个数的大小,测试某个数据是正还是负,测试数据的某位是“0”还是“1”等,将处理的结果反映在标志寄存器的CF, ZF, SF, DF和OF位上。   ② 根据转移条件选择适当的转移指令。通常一条条件转移指令只能产生两路分支,因此要产生 n路分支需n-1条条件转移指令。   ③ 各分支之间不能产生干扰,如果产生干扰,可用无条件转移语句进行隔离。 【例】在以ADDR为首地址的内存单元中,存放着两个字节类型的无符号数x1和x2,比较这两个数的大 小,并将大数存放在内存RESULT单元中。 解题思路:比较两个无符号数的大小,可用CMP指令进行,并利用借位标志CF来判断大小。程序流程如图所示。 程序如下。 DATA SEGMENT ADDR DB X1, X2 RESULT DB DATA ENDS CODE SEGMENT ASSUME CS: CODE, DS: DATA START: MOV AX, DATA MOV DS, AX 若X1=0FFH, X2=3BH,则运行结果为: X1=0FFH, X2=3BH RESULT: FFH MOV AL, ADDR ; AX←X1 CMP AL, ADDR+1 ; X1-X2 JNC LOOP1 ; 若X1≥X2→LOOP1 MOV AL, ADDR+1 ; 若X1<X2, AL←X2 LOOP1: MOV RESULT, AL ; 将大数存入RESULT单元中 MOV AH, 4CH INT 21H CODE ENDS END START 假设任意给定x值,存放在内存RS1单元中,求出函数y的值,存放在内存RS2单元中。程序流程如图所示。 程序如下 DATA SEGMENT RS1 DB X ; 存放自变量X RS2 DB ; 函数Y值的存储单元 DATA ENDS CODE SEGMENT ASSUME CS: CODE, DS: DATA START: MOV AX, DATA MOV DS,

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值