汇编语言程序设计顺序分支.ppt
文本预览下载声明
3.1 汇编语言程序设计 顺序结构程序——简单程序结构 无分支、无循环、无转移程序。流程图的特点,表现为只有起始、终止框、说明处理框,而无判断框。 例、用字节加法,对两个16位数做加法运算。这两个数从地址0050H开绐连续存放。 程序清单如下: MOV AX,DATA MOV DS,AX MOV SI,0050H ;被加数指针 MOV DI,0052H ;加数指针 MOV BX,0054H ;和的指针 MOV AL,[SI] ;取被加数低8位 ADD AL,[DI] ;低位相加 MOV AH,[SI+1] ;取被加数高8位 ADC AH,[DI+1] ;高位相加 MOV [BX],AX ;保存运算结果 INT 20H ;结束 起 始 终 止 保存运算结果 AH=高8位相加 AH=被加数高8位 AL=低8位相加 AL=被加数低8位 SI=50H,DI=52H,BX=54H DS=3000H 数据段定义为: DATA SEGMENT ORG 0050H DB 34H DB 12H DB 78H DB 56H DB 2 DUP(?) DATA ENDS 如数据段定义为: DATA SEGMENT ORG 0050H DW 1234H DW 5678H DW ? DATA ENDS 程序也可改为: MOV AX,DATA MOV DS,AX MOV SI,0050H ;被加数指针 ;MOV DI,0052H ;加数指针 MOV BX,0054H ;和的指针 MOV AX,[SI] ;取被加数低8位 ADD AX,[DI] ;低位相加 MOV [BX],AX ;保存运算结果 INT 20H ;结束 3.1 汇编语言程序设计 例、编写计算f=(V-(X*Y+Z-500))/X的程序。X、Y、Z、V均为有符号16 位二进制数。 DATA SEGMENT X DW 0100H Y DW 01ABH Z DW -2100H V DW 6200H F DW ?, ? DATA ENDS CODE SEGMENT ASSUME CS:CODE, DS:DATA START: MOV AX,DATA MOV DS,AX MOV AX,X IMUL Y ;DX:AX=X*Y ADD AX,Z ADC DX,0 ;DX:AX=X*Y+Z SUB AX,500H SBB DX,0 ;DX:AX=( ) 此处注意进位和借位的处理方法。 MOV BX,AX MOV CX,DX ;保存中间结果 MOV AX,V CWD ;DX:AX=V SUB AX,BX SBB DX,CX ;DX:AX=((V-( )) IDIV X MOV AH, 4CH INT 21H CODE ENDS END START MOV F,AX ;保存商 MOV F+2,DX ;保存余数 3.1 汇编语言程序设计 分支结构程序 分支程序是利用条件转移指令,使程序执行到某一指令后,根据运算状态标志条件是否满足,来改变程序执行的次序。分支程序的结构如图所示。 条件 程序段1 程序段2 Y N Y= 1当X0 (-128≤x ≤127) 0当X=0 -1当X0 例1 符号函数 3.1 汇编语言程序设计 分支结构程序 Y= 1当X0 (-128≤x ≤127) 0当X=0 -1当X0 例1 符号函数 起 始 取数 终 止 保存结果 Y=1 Y=0 Y=FFH=-1 X=0? Y N X0? Y N MOV AL,XX CMP AL,0 JGE BIGR MOV AL,0FFH ;x0 MOV YY,AL HLT BIGR: JE EQUL MOV AL,1 MOV YY,AL ;x0 HLT EQUL: MOV YY,AL ;X=0 HLT 3.1 汇编语言程序设计 分支结构程序 例2、? 求AX和BX中两无符号数之差的绝对值,结果放在内存200H单元中。 方法1 用比较指令完成 MOV AX,[300H] MOV BX,[302H] CMP AX,BX JA AA SUB BX,AX MOV [200H],BX INT 20H AA: SUB AX,BX MOV [200H],AX INT 20H 分析:AX和BX的数未知。两数相减求绝对值,应先解决哪一个值稍大些,然后再用大数减小数的方法,才可求得绝对值。 3.1 汇编语言程序设计 分支结构程序 例2、求AX和BX中两无符号数之差的
显示全部