汇编语言 第五章

合集下载

微机原理与汇编语言第5章汇编语言程序设计

微机原理与汇编语言第5章汇编语言程序设计
(2) 约定段寄存器和段的关系(即物理段和逻辑 段的关系,使用一个或多个ASSUME语句实现)
(3) 装填段寄存器(只装填数据型段寄存器)
(4) 设置返回DOS的方法
例如:
MYDARA SEGMENT ……
MYDATA ENDS MYCODE SEGMENT
ASSUME CS:MYCODE,DS:MYDATA START:
无法正常连接
有算法错误
LINK .EXE文件
(1) 编辑程序
DOS 环境下用 EDIT 编辑器
WINDOWS 环境下用 记事本
(2)汇编源程序
宏汇编程序 MASM.EXE 或小汇编程序 汇编程序主要有以下功能:
① 检查源程序中语法错误,给出错误提示信息 ② 产生目标文件(.OBJ)、列表文件(.LST)及 交叉引用文件(.CRF) ③ 展开宏指令
end start
汇编后的目 标文件只有 208字节
汇编语言源程序的格式
例二 编程实现多字节加法,如 S=3B74AC60F8H+20D59E36C1H
DATA1
F8H 60H ACH 74H 3BH
……
被加数、和
DATA2
C1H 36H 9EH D5H 20H
加数
DATA SEGMENT
DATA1 DB 0F8H, 60H, 0ACH, 74H, 3BH
(3) 操作数
操作数即为操作的对象。在指令语句中,可能有 单操作数或双操作数,也可能无操作数或隐含操作数; 而在伪指令中可能有更多个操作数。当操作数不止一个 时,相互之间应该用逗号隔开。
可以作为操作数的有:常数、寄存器、标号、变量 和表达式等。
1) 常量:是指令在中出现的哪些固定值, 可以分为数值常数和字符串常数两类。

第五章 DSP的汇编指令..

第五章 DSP的汇编指令..

第五章 TMS320C55x系列DSP的汇编指令
(2) 用户自定义的双指令的并行
这两条指令的并行是通过用户或C编译器定义的。两条指令 同时执行两个操作,用并行符“||”区分并行执行的两条指令。 例:
MPYM *AR1+, *CDP, AC1 ;D单元的一个MAC来完成
||XOR AR2,T1
;A单元的ALU来完成
第五章 TMS320C55x系列DSP的汇编指令
1、高速数字信号处理中常采用汇编语言编程。 2、汇编语言中的两种指令集 (1) 助记符指令集:有助于记忆的符号来表示指令。 (2) 代数指令集:类似于代数表达式,运算关系清楚明了。 注意:DSP的软件开发工具只支持单一的指令形式,不支持助记
符指令和代数指令的混合形式。 3、术语、符号和缩写见P93的表5-1 4、运算符见表5-2
令执行的条件:
TCx(测试/控制标志为1) !TCx(测试/控制标志为0)
TC1&TC2 TC1&!TC2 TC1|TC2 TC1|!TC2 TC1^TC2 TC1^!TC2
!TC1&TC2 !TC1&!TC2 !TC1|TC2 !TC1|!TC2 !TC1^TC2 !TC1^!TC2
第五章 TMS320C55x系列DSP的汇编指令
4、双16比特算术指令: [(1)语法、(2)操作数、(3)状态位] 在D单元中利用其ALU的双16比特模式,同时执行(并行)两个16
比特算术运算,包括加-减、减-加、两个加和两个减运算。
例:
说明: NO:不能并行执行 3:指令的长度为3字节 1:周期为1 X:在X(执行)流水线阶段处理
D – ALU:在D单元ALU执行。 执行结果:AC0=(*AR3)+CARRY+AC1 状态位: Affected by CARRY,C54CM,M40等

汇编第五章课后题答案

汇编第五章课后题答案

1.从屏幕上输入小写字母,转化为大写字母输出(解法1)DATA SEGMENTMESSAGE DB "ENTER A STRING:",0AH,0DH,'$' MAXLENGTH DB 50,?,50 DUP(?) ;每次最多可以输入49个字符DATA ENDSCODE SEGMENTASSUME DS:DATA,CS:CODESTART:MOV AX,DATAMOV DS,AXLEA DX,MESSAGE ;输出ENTER A STRINGMOV AH,09HINT 21HLEA DX,MAXLENGTH ;输入字符串MOV AH,0AH ;键盘输入到缓冲区,DS:DX=缓冲区首址INT 21H ;(DS:DX)=缓冲区最大字符数,(DS:DX+1)=实际输入的字符数MOV AH,02H ;输出回车换行MOV DL,0AHINT 21HMOV AH,02HMOV DL,0DHINT 21HMOV CL,MAXLENGTH+1;把字符的实际长度放入寄存器CLMOV CH,0MOV BH,02HLEA SI,MAXLENGTH+2;取字符串的基地址放入SIXUN:MOV AL,[SI]CMP AL,'Z'JBE S1 ;小于等于'Z'转移JMP S3S1:CMP AL,'A'JAE DA ;大于等于'A'转移JMP OUTPUTDA:ADD AL,20HJMP OUTPUTS3:CMP AL,'z' ;小于等于小Z转移JBE S4S4:CMP AL,'a' ;大于等于小a转移JAE XIAOJMP OUTPUTXIAO:SUB AL,32JMP OUTPUTOUTPUT:MOV DL,ALMOV AH,02H ;显示输出INT 21HINC SILOOP XUNMOV AH,4CHINT 21HCODE ENDSEND START(解法2);将输入的小写字母转化为大写字母输出,输入回车结束CODE SEGMENTASSUME CS:CODEBEGIN:MOV AH,01HINT 21HCMP AL,0DH ;ASCII OF CARRIAGE RETURNJE EXITCMP AL,61H ;ASCII OF 'a'JB STOPCMP AL,7AH ;ASCII OF 'z'JA STOPSUB AL,20HSTOP:MOV DL,ALMOV AH,2INT 21HJMP BEGINEXIT:MOV AH,4CHINT 21HRETCODE ENDSEND BEGIN2.输入一个字符,找出它的前导字符和后续字符,并按顺序显示这三个字符.(解法1)CODE SEGMENTMAIN PROC FARASSUME CS:CODESTART:PUSH DSXOR AX,AXPUSH AXMOV AH,01HINT 21HCMP AL,61HJB EXITCMP AL,7AHJA EXITMOV CL,ALDEC ALMOV DL,ALMOV AH,02HINT 21HMOV DL,CLMOV AH,02HINT 21HAND AL,01HINC CLMOV DL,CLMOV AH,02HINT 21HEXIT:MOV AX,4C00HINT 21HRETMAIN ENDPCODE ENDSEND START(解法2).MODEL SMALL.STACK 200H.DATAimsg db 'Input:$' ;输入提示信息omsg db 0Dh,0Ah,'Output:$' ;输出提示信息string db 3 dup(0),'$' ;存放三个字符.CODESTART:mov ax,@datamov ds,axlea dx,imsgmov ah,9int 21hmov ah,1int 21hlea di,stringdec almov cx,3s:mov [di],alinc diinc alloop slea dx,omsgmov ah,9int 21hlea dx,stringmov ah,9int 21hMOV AH,07HINT 21HMOV AX,4C00HINT 21HEND START3.将AX寄存器中的16位数分成4组,每组4位,然后把这四组数分别放在AL,BL,CL,DL中.MODEL SMALL,C.CODE.STARTUPMOV AX,3456HMOV BX,AXMOV CL,4ROL AX,CLMOV BX,AXAND AL,0FH ;AL中是15,14,13,12ROL BX,CLMOV DX,BXAND BL,0FH ;BL中是11,10,9,8AND AH,0FHMOV CH,AH ;CH中是7,6,5,4MOV CL,CHAND DH,0FH ;DH中是3,2,1,0MOV DL,DH.EXIT 0END4.试编写一程序,要求比较两个字符串STRING1和STRING2所含字符是否相同,若相同则显示'MATCH',若不相同则显示'NOT MATCH'..MODEL SMALL.DATASTRING1 DB "LDSKFJSLDKF"LENG1 EQU $-STRING1STRING2 DB "LDSKFJSLDKP"LENG2 EQU $-STRING2MSG1 DB "MATCH",24HMSG2 DB "NOT MATCH",24H.CODEMOV AX,@DATAMOV DS,AXMOV ES,AXMOV BX,LENG1MOV CX,LENG2CMP BX,CXJNZ NOT_MATCHLEA SI,STRING1LEA DI,STRING2CLDREPZ CMPSBJZ _MATCHNOT_MATCH:LEA DX,MSG2MOV AH,09HINT 21HJMP _EXIT_MATCH:LEA DX,MSG1MOV AH,09HINT 21H_EXIT:MOV AH,07HINT 21HMOV AX,4C00HINT 21HEND5.要求能从键盘接收一个个位数,然后响铃N次(响铃的ASCII码为07) .MODEL SMALL.DATAMSG DB "YOUR INPUT IS NOT 1-9!",24H .CODE.STARTUPMOV AH,0INT 16H ;接收一个键盘输入CMP AL,31HJB ERRORCMP AL,39HJA ERRORMOV CL,ALSUB CL,30HCYCLE:MOV DL,7MOV AH,09HINT 21HMOV AH,07H ;按一下键就响一下铃声INT 21HLOOP CYCLEJMP _EXITERROR:LEA DX,MSGMOV AH,09HINT 21HMOV AH,07HINT 21H_EXIT:.EXIT 0END6.编写程序,将一个包含有20个数据的数组M分成两个数组,正数数组P 和负数数组N,并分别把这两个数组中数据的个数显示出来..MODEL SMALL,C.DATAINDEX DB 12,-20,4,05H,11H,2AH,-11,2,3,09HDB -3,0,-9,44H,32H,33H,34H,-5,40H,22HP DB 0,20 DUP(0) ;存放正数N DB 0,20 DUP(0) ;存放负数.CODEDISPLAY PROC NEAR USES AXAND AH,0FH.IF AH>= 0AH && AH<= 0FHADD AH,07H.ENDIFADD AH,30HMOV DL,AHMOV AH,02HINT 21HMOV AH,07HINT 21HRETDISPLAY ENDP.STARTUPLEA DI,P+1LEA SI,N+1LEA BX,INDEXMOV CX,14HCYCLE:CMP BYTE PTR [BX],0JG NOSIGNINC AL ;AL中存放负数MOV DL,BYTE PTR [BX]MOV BYTE PTR DS:[DI],DLINC DIINC BXLOOP CYCLENOSIGN:INC AH ;AH中存放正数MOV DL,BYTE PTR [BX]MOV BYTE PTR DS:[SI],DLINC SIINC BXLOOP CYCLEMOV P,AHMOV N,ALCALL DISPLAYMOV AH,ALCALL DISPLAY.EXIT 0END7.试编制一个汇编语言程序,求出首地址为DATA的100D字数组中的最小偶数,并把它存放在AX中.datarea segmentdata dw 10,2,4,8,7,7,69,65,55,89,95dw 25,39,77,88,25,1,47,88,8,8,77,88,22 count=($-data)/2num dw 0ffeehdatarea endscode segmentmain proc farassume cs:code,ds:datareapush dsmov ax,0push axbegin:mov ax,datareamov ds,axmov bl,2mov cx,countlea si,dataA:mov ax,[si]mov dx,axdiv blcmp ah,0jne circlecmp dx,numjb Bcircle:add si,2lopa:loop Aexit:mov ax,numretB:mov num,dxjmp lopamain endpcode endsend8.把AX中存放的16位二进制数K看作是8个二进制的"四分之一字节".试编写一程序,要求数一下值为3(即11B)的四分之一字节数,并将该数在终端上显示出来.MOV CX,8MOV DL,0NEXT3:ROR AX,1JNC NEXT1ROR AX,1JNC NEXT2INC DLNEXT2:LOOP NEXT3ADD DL, 30HMOV AH, 2INT 21HMOV AH, 4CHINT 21HNEXT1:ROR AX, 1JMP NEXT29.试编写一汇编语言程序,求出首地址为DATA的100D字数组中的最小偶数,并把它存放在AX中..MODEL SMALL,C.DATA_DATA DW 100 DUP(?).CODE.STARTUPLEA SI,_DATAMOV AX,[SI]MOV CX,100CYCLE:ADD SI,2.IF AX< [SI]MOV AX,[SI].ENDIFLOOP CYCLE.EXIT 010.设有一段英文,其字符变量名为ENG,并以$字符结束,试编写一程序,查对单词SUN在该文中的出现次数,并以格式"SUN****"显示出次数..MODEL SMALL.386.DATAENG DB 'SUN','SUN JAVA',24HMESSAGE DB 'SUN:','$' .STACK 100H.CODEMAIN PROC FAR START:PUSH DSAND AX,0PUSH AXMOV AX,@DATAMOV DS,AXMOV AX,0HMOV SI,1HSUBSI1:SUB SI,1HSUBSI2:SUB SI,1H COMPARES:ADD SI,1HMOV DL,ENG[SI]CMP DL,24HJE PRINTCMP DL,53HJNE COMPARES COMPAREU:ADD SI,1HMOV DL,ENG[SI]CMP DL,55HJNE SUBSI2 COMPAREN:ADD SI,1HMOV DL,ENG[SI]CMP DL,4EHJNE SUBSI1INC AXJMP COMPARESPRINT:LEA DX,MESSAGEPUSH AXMOV AH,09HINT 21HPOP AXCALL SHOWNUMBER EXIT:RETMAIN ENDP SHOWNUMBER PROC NEAR COVERNUM:DAAMOV DX,AXMOV CL,4HSHOW:ROL DX,4HPUSH DXAND DX,0FHADD DX,30HMOV AH,02HINT 21HPOP DXLOOP SHOWRETSHOWNUMBER ENDPEND START11.从键盘输入一系列以$为结束符的字符串,然后对其中的非数字字符计数,并显示出计数结果..MODEL SMALL.386.CODEMAIN PROC FARSTART:PUSH DSMOV AX,0PUSH AXMOV CX,0INPUT:MOV AH,1HINT 21HCOMPARE:CMP AL,24HJE PRINTCMP AL,30HJL ADDCOUNTCMP AL,39HJG ADDCOUNTADDCOUNT:ADD AX,1HJMP INPUTCALL SHOWNUMBEREXIT: RETMAIN ENDPSHOWNUMBER PROC NEARCOVERNUM:DAAMOV DX,AXMOV CL,2HSHOW:ROL DL,4HPUSH DXAND DL,0FHADD DL,30HMOV AH,02HINT 21HPOP DXLOOP SHOWRETSHOWNUMBER ENDPEND START12.有一个首地址为MEM的100D字数组,试编制程序删除数组中所有为零的项,并将后续项向前压缩,最后将数组的剩余部分补上零..model small.386.stack 100Hmem dw12,0,0,0,0,0,1,2,3,6,4,7,8,2,1,0,0,54,5,0,2,4,7,8,0,5,6,2,1,4,8,5,1,45,7 ,5,1,2,0,2,4,0,2,54,0,12,0,0,0,0,0,1,2,3,6,4,7,8,2,1,0,0,54,5,0,2,4,7,8,0,5,6,2,1,4,8,5,1,45,7,5,1, 2,0,2,4,0,2,54,0,45,7,5,1,2,0,2,4,0,2.codeMAIN PROC FARstart:push dsand ax,0push axmov ax,@datamov ds,axmov ax,0Hmov bx,64Hmov cx,64Hmov si,0FFFEHrepeat:ADD si,2Hcmp MEM[si],0HJE callsloop repeatcalls:INC axcall sortcmp ax,1HJE lastValueDEC cxjmp repeatexit :retlastValue:mov mem[bx],0HDEC cxjmp repeatMAIN ENDPsort PROC NEARpush cxpush sisub si,2Hs:add si,2Hmov dx,mem[si]mov mem[si+2],dxloop sreturn:pop sipop cxretsort ENDPEND start13.在STRING到STRING+99单元中存放着一个字符串,试编制一程序测试该字符串中是否存在数字.如有,则把CL的第5位置1,否则将该位置0. DSEG SEGMENTA DW ?B DW ?DSEG ENDSCSEG SEGMENTMAIN PROC FARASSUME CS:CSEG,DS:DSEG START:PUSH DSSUB AX, AXPUSH AXMOV AX, DSEGMOV DS, AXBEGIN:MOV AX, AMOV AX, BXOR AX, BXTEST AX, 0001JZ EXITXCHG BX, AMOV B, BXJMP EXITCLASS:TEST BX, 0001JZ EXITINC BINC AEXIT:RETMAIN ENDPCSEG ENDSEND START14.在首地址为TABLE的数组中按递增次序存放着100H个16位补码数,试编写一个程序把出现次数最多的数及其出现次数分别存放在AX和CX中.DATA SEGMENTTABLE DW 100H DUP (?)MDATA DW ? ; 存放出现次数最多的数COUNT DW 0 ; 存放出现次数DATA ENDSCODE SEGMENTASSUME CS:CODE,DS:DATASTART:MOV AX,DATAMOV DS,AXMOV BX, 100HMOV DI, 0 ; DI为数组TABLE的指针NEXT:MOV DX, 0MOV SI, 0MOV AX, TABLE[DI]MOV CX, 100HCOMP:CMP TABLE[SI], AXJNE _ADDRINC DX_ADDR:ADD SI, 2LOOP COMPCMP DX, COUNTJLE CHANGMOV COUNT, DXMOV MDATA, AXCHANG:ADD DI, 2DEC BXJNZ NEXTMOV CX, COUNTMOV AX, MDATAMOV AX,4C00HINT 21HCODE ENDSEND START15.数据段中已定义了一个有n个字数据的数组M,试编写一程序求出M 中绝对值最大的数,把它放在数据段的M+2n单元中,并将该数的偏移地址存放在M+2(n+1)单元中.DSEG SEGMENTX DW -4FX DW ?DSEG ENDSCSEG SEGMENTMAIN PROC FARASSUME CS:CSEG,DS:DSEGSTART:PUSH DSPUSH AXMOV AX, DSEGMOV DS, AXBEGIN:CMP X, 5JG A0CMP X, -5JL A0MOV BX,1SUB BX, XMOV FX, BXRETA0:MOV FX, 0RETMAIN ENDPCSEG ENDSEND START16.在首地址为DATA的字数组中,存放了100H个16位补码数,试编写一程序,求出它们的平均值放在AX寄存器中;并求出数组中有多少个数小于此平均值,将结果放在BX寄存器中..MODEL SMALL.STACK 200H.DATADA_TA DW 100H DUP(?).CODE.STARTUPXOR BX,BXXOR DX,DXMOV CX,100HLEA SI,DA_TACYCLE:ADD AX,[SI]ADC DX,0INC SIINC SIDEC CXCMP CX,0JNZ CYCLEMOV CX,100HDIV CX ;计算平均值,存放在AX中.LEA SI,DA_TACOMPARE:CMP AX,[SI]JA NEXT ;计算小于AX的值,其个数存放在BX中INC BXNEXT:INC SIINC SIDEC CXCMP CX,0JNZ COMPARE.EXIT 0END17.试编制一个程序,把AX中的16进制数转化为ASCII码,并将对应的ASCII码依次存放到MEM数组中的四个字节中.例如:当(AX)=2A49H时,程序执行完后,MEM中的4个字节内容为39H,34H,41H,32H.;MODE=DOSDATA SEGMENTSOURCE DW 2A49HMEM DB 4 DUP(?)DATA ENDSCODE SEGMENTASSUME CS:CODE,DS:DATASTART:MOV AX,DATAMOV DS,AXMOV DX,SOURCELEA BX,MEMMOV CX,4LB:MOV AX,DXAND AX,000FHCMP AL,10JC ADADD AL,7AD:ADD AL,30HMOV [BX],ALINC BXSHR DX,1SHR DX,1SHR DX,1SHR DX,1LOOP LBMOV AH,4CHINT 21HCODE ENDSEND START18.把0-100D之间的30个数存入以GRADE为首地址的30个字数组中,GRADE+i表示学号为i+1的学生成绩.另一个数组RANK为30个学生的名次表,其中RANK+i的内容是学号为i+1的学生的名次.编写一程序,根据GRADE中的学生成绩,将学生名次填入RANK数组中.(提示:一个学生的名次等于成绩高于这个学生的人数加1)DSEG SEGMENTGRADE DW 30 DUP(?)RANK DW 30 DUP(0)DSEG ENDSCSEG SEGMENTMAIN PROC FARASSUME CS:CSEG,DS:DSEGSTART: PUSH DSSUB AX,AXPUSH AXMOV AX,DSEGMOV DS,AXBEGIN:MOV DI,0MOV CX,30LOOP1:PUSH CXMOV CX,30MOV SI,0MOV AX,GRADE[DI]MOV DX,0LOOP2:CMP GRAD[SI],AXJBE GOONINC DXGOON :ADD SI,2LOOP LOOP2POP CXINC DXMOV RANK[DI],DXADD DI,2LOOP LOOP1RETMAIN ENDPCSEG ENDSEND START19.已知数组A包含15个互不相等的整数,数组B包含20个互不相等的整数.试编制一程序,把既在A中又在B中出现的整数存放于数组C中。

汇编语言流程图++

汇编语言流程图++
实现方法:在产生分支之前,通常用比较、测试的办 法在标志寄存器中设置相应的标志位,然后再选用适当 的条件转移指令,以实现不同情况的分支转移。
(1)进行比较,使用比较指令:
CMP DEST,SRC
该指令进行减法操作,而不保存结果,只设置标志位。
(2)进行测试,使用测试指令
TEST DEST,SRC
该指令进行逻辑与操作,而不保存结果,只设置标志位。
;各分支程序段
A1:
MOV INT
LEA
AH,9 21H
DX,S1
JMP
A2: MOV INT JMP
EXIT1
LEA AH,9 21H EXIT1 DX,S2
ERROR:MOV MOV INT EXIT1: MOV
DX,OFFSET ER AH,9 21H AH,4CH ;返回DOS
INT
CODE END ENDS START
解:完成该功能的流程图如图5.2所示:
开始 AL←(X) AL←(AL)×4 AL←(AL)-(Y) AL←(AL)/2 Z←(AL) 结束
图5.2 例5.1的功能实现流程图
参考程序1: DATA X Y Z DATA SEGMENT DB DB DB ENDS PARA STACK 2 4 ? ;定义变量 ;数据段
TAB
参考程序: DATA SEGMENT
: A0-L A0-H A1-L A1-H A2-L A2-H :
MENU DB
0DH,0AH,"0:Chinese!"
DB
DB
0DH,0AH,"1:English!"
0DH,0AH,"2: German!" choose one to answer the following

第五章 汇编语言程序设计(作业)

第五章  汇编语言程序设计(作业)

第20题-Leabharlann 3MOV AH,4CH INT 21H START ENDP CODE ENDS END BEGIN 上述程序运行结束后,BUF中各字节单元 内容是什么?
P.43 第21题
已知程序如下,执行该程序后,回答下述问题: DATA SEGEMNT BLOCK DW 2,$+2,5,7,$+6,0DH COUNT EQU $-BLOCK-2; COUNT←10 AREA1 DB COUNT DUP(?) AREA EQU AREA1+COUNT-1 ; 地址表达式,AREA←0015H DATA ENDS STACK SEGMENT PARA STACK ‘STACK’ DB 100 DUP(?) STACK ENDS
第24题-续1
CODE SEGMENT ASSUME CS:CODE,DS:DATA,ES:DATA START PROC FAR MOV AX,DATA MOV DS,AX MOV ES,AX
第24题-续2
LEA DI,AA; 建立指针 LEA SI,BB AND AX,AX; CF←0 MOV BX,OFFSET CC+4; BX←000CH MOV CX,COUNT; CX←4 MOV AL,[DI+03H] ADC AL,[SI+03H] MOV [BX],AL DEC BX DEC DI DEC SI LOOP MU1 MOV AL,00H; AL←00H RCL AL,1 MOV [BX],AL
第30题-续2
MAIN CODE RET ENDP ENDS END MAIN
第30题-续3
回答以下问题: 1)该程序的功能是 统计NUM中1的个数 。 2)程序运行结束时,RESULT单元的内容 是 3 。 3)指令AND AX,AX在程序中的作用是 判 断AX的内容是否为0 。

第5章 汇编语言程序

第5章 汇编语言程序

Y
条件满足?
N
处理段
例5-5 设内部RAM30H,31H单元存放两个无符号数, 将大数存在31H,小数存于30H。 ORG 1000H START:CLR C MOV A,30H SUBB A,31H JC NEXT ;次序符合,返回 MOV A,30H ;交换 XCH A,31H MOV 30H,A NEXT: NOP SJMP $ END
$
5-3 分支程序
由条件转移指令构成程序判断框,形成程序分支结构。 5-3-1 单重分支程序 一个判断决策框,程序有两条出路。 两种分支结构: 例1 求R2中补码绝对值,正数不变, 影响条件 负数变补。
MOV A,R2 JNB ACC.7,NEXT;为正数? CPL A ;负数变补 INC A MOV R2,A NEXT:SJMP NEXT ;结束
五、对源程序进行交叉汇编得到机器代码; 反汇编 —— 分析现成产品的程序,要将二进制 的机器代码语言程序翻译成汇编语言源程序。
六、程序调试。
通过微计算机的串行口(或并行口)把机器代 码传送到用户样机(或在线仿真器)进行程序 的调试和运行。
5.1.3评价程序质量的标准
(1)程序的执行时间。 (2)程序所占用的内存字节数。 (3)程序的逻辑性、可读性。 (4)程序的兼容性、可扩展性。 (5)程序的可靠性。
方法二:采用除10H取余数将BCD拆开 ORG 1000H MOV A,20H; 2B 1T MOV B,#10H ; 3B 2T DIV AB ; 1B 4T ORL B,#30H ; 3B 2T MOV 22H,B ; 3B 2T ORL A,#30H; 2B 1T MOV 21H,A ; 2B 1T SJMP $ END;7条指令、16个内存字节、13个机器周期。

汇编语言课程设计动画设计

汇编语言课程设计动画设计

汇编语言课程设计动画设计一、课程目标知识目标:1. 让学生掌握汇编语言的基本概念和原理,理解汇编语言与计算机硬件的紧密联系。

2. 使学生了解动画设计的基本原理,掌握汇编语言在动画设计中的应用方法。

3. 帮助学生掌握汇编语言编程技巧,提高解决实际问题的能力。

技能目标:1. 培养学生运用汇编语言编写简单动画程序的能力。

2. 培养学生运用汇编语言进行程序调试和优化的能力。

3. 提高学生分析问题和解决问题的能力,培养创新思维和团队协作精神。

情感态度价值观目标:1. 培养学生对计算机编程和动画设计的兴趣,激发学习热情。

2. 培养学生勇于尝试、不断探索的精神,增强自信心。

3. 使学生认识到汇编语言在计算机科学中的地位和作用,提高社会责任感。

课程性质分析:本课程为信息技术课程,旨在让学生掌握汇编语言编程技能,培养其在动画设计领域的实际应用能力。

学生特点分析:学生为高中生,具备一定的计算机操作基础和编程知识,对新鲜事物充满好奇,但可能对汇编语言较为陌生。

教学要求:1. 理论与实践相结合,注重培养学生的实际操作能力。

2. 创设情境,激发学生的学习兴趣和主动性。

3. 注重分层教学,关注学生个体差异,提高全体学生的编程素养。

二、教学内容1. 汇编语言基础知识:介绍汇编语言的基本概念、语法和指令系统,重点讲解与动画设计相关的寄存器、内存操作等内容。

- 教材章节:第一章 汇编语言概述,第二章 指令系统与语法- 内容列举:数据类型、寄存器、指令格式、寻址方式等2. 动画设计原理:讲解动画设计的基本原理,如帧动画、逐行绘制等,分析汇编语言在动画设计中的应用。

- 教材章节:第三章 动画设计基础- 内容列举:动画原理、帧动画、逐行绘制、颜色表示等3. 汇编语言编程实践:通过实例教学,让学生掌握汇编语言编程技巧,学会编写简单动画程序。

- 教材章节:第四章 汇编语言编程实践- 内容列举:汇编语言编程环境、编写源程序、编译与链接、程序调试与优化等4. 动画设计实例分析:分析经典动画设计实例,让学生了解汇编语言在实际动画制作中的应用。

汇编语言第5章作业答案

汇编语言第5章作业答案

习题51.试说明以下指令中各操作数的寻址方式,如果是存储器寻址,请给出其EA计算公式,并说明所使用的段寄存器。

(1)MOV AL,08H 源操作数:立即数寻址目的操作数:寄存器寻址(2)MOV [0120H],BL 源操作数:寄存器寻址目的操作数:直接寻址,EA=0120H,使用DS段寄存器(3)ADD [BX],AL 源操作数:寄存器寻址目的操作数:寄存器间接寻址,EA=(BX),使用DS段寄存器(4)PUSH [SI]0200H 源操作数:变址寻址,EA=(SI)+0200H,使用DS段寄存器目的操作数:隐含寻址(指令中未直接体现)(5)SUB AX,[BP] 源操作数:寄存器间接寻址,EA=(BP),使用SS段寄存器目的操作数:寄存器寻址(6)AND V AR1+4,DL 源操作数:寄存器寻址目的操作数:直接寻址,EA=V AR1+4,使用DS段寄存器(7)PUSHF 源操作数、目的操作数均为隐含寻址(8)MOV ES : [BX]0100H, AL 源操作数:寄存器寻址目的操作数:基址寻址,EA=(BX)+0100H,用ES段寄存器(9)ADC BYTE PTR [BP][SI]0210H,45H源操作数:立即数寻址目的操作数:基址变址寻址,EA=(BP)+(SI)+0210H,使用SS段寄存器(10)OR ARRY[BX][DI],CL源操作数:寄存器寻址目的操作数:基址变址寻址,EA=(BX)+(DI)+ARRY,使用DS段寄存器2.试分析下列汇编指令是否存在语法错误,如果有语法错误存在,请说明是怎样的错误。

(1)PUSH 8243H错误,单操作数指令不能使用立即数(2)POP AL错误,进栈、出栈指令的操作数应为16位(3)MOV AL,6543H错误,源、目的操作数类型不匹配(4)ADD [0100H],64H错误,目的操作数应使用PTR运算符指出类型,否则具有二义性正确的写法:ADD BYTE PTR [0100H],64H,(或使用WORD PTR)(5)ADC V AR1,V AR2错误,8086指令系统的双操作数指令中,必须有一个是寄存器,不能两个操作数同为内存单元(6)MOV DS,ES错误,段寄存器间不能使用MOV指令直接传递数据,必须通过通用寄存器作为中转(7)MOV DS,0620H错误,使用MOV指令向段寄存器传递数据时,不能使用立即数(8)LEA BX,AX错误,L EA指令的源操作数必须为内存单元(9)DEC AL,AH错误,DEC指令为单操作数指令(10)SHR BL,3错误,当移位次数大于1时,在移位指令中特定使用CL寄存器给出移位次数正确的写法:MOV CL, 3SHR BL, CL3.试说明分别执行下列各组指令后,CF、OF、AF、ZF、SF、PF这六个状态标志分别是怎样的取值。

第5章 习题及答案

第5章 习题及答案

第五章 汇编语言程序设计1、画图说明下列语句所分配的存储器空间及初始化的数据值。

难度:2(1) BYTE_VAR DB ‘BYTE’,12,-12H ,3 DUP(0,2 DUP(1,2),7) (2) WORD_VAR DW 3 DUP(0,1,2),7,-5,’BY’,’TE’,256H 答:(1) (2)07H BYTE_V AR 42H WORD_V AR 00H 00H 59H 00H FBH 54H 01H FFH 45H 00H 59H 0CH 02H 42H EEH 00H 45H 00H 00H 54H 01H 00H 56H 02H 01H 02H 01H 00H 02H 02H 07H 00H 00H 00H 01H 00H 02H 01H 01H 00H 02H 02H 07H 00H 00H 00H 01H 00H 02H 01H 01H 00H 02H 02H07H00H2、假设程序中的数据定义如下: PARTNO DW ?PNAME DB 16 DUP(?) COUNT DD ? PLENTH EQU $- PARTNO 问:PLENTH 的值为多少?他表示什么意义? 答:PLENTH 的值为22,它表示当前已分配单元空间。

《微型计算机原理》第5章习题与解答3、有符号定义语句如下:难度:2BUF DB 1,2,3,’123’EBUF DB 0L EQU EBUF-BUF问:L的值是多少?答:L的值为6;4、假设成序中的数据定义如下:难度:2LNAME DB 30 DUP(?)ADDRESS DB 30 DUP(?)CITY DB 15 DUP(?)CODE_LIST DB 1,7,8,3,2(1)用一条MOV指令将LNAME的偏移地址存入BX。

(2)用一条指令将CODE_LIST的头两个字节的内容放入SI。

(3)写一条伪指令定义符使CODE_LENGTH的值等于 CODE_LIST域的实际长度。

汇编语言程序设计复习

汇编语言程序设计复习

知识点第一章基础知识(1)正负数的补码表示, 掌握计算机中数和字符的表示;eg.假设机器字长为8位,[+3]补=00000011B,[-3]补= 11111101 H 。

十六进制数0FFF8H表示的十进制正数为65528D,表示的十进制负数为-8D。

8位二进制数被看成是带符号补码整数时,其最小值是-128,最大值是 127 。

第二章80x86计算机组织(1)中央处理机CPU的组成和80x86寄存器组,重点:专用寄存器,段寄存器eg: IP寄存器中保存的是?代码段中的偏移地址FLAGS标志寄存器中共有几位条件状态位6位,有几位控制状态位2位,标志寄存器分为哪2类?陷阱标志,中断标志。

(2)存储单元的地址和内容每一个字节单元给以一个唯一的存储器地址,称为物理地址;一个存储单元中存放的信息称为该存储单元的内容。

存储器地址的分段,(低位字节存放)低地址,(高位字节存放)高地址;实模式下逻辑地址、选择器和偏移地址;物理地址的表示段基地址加上偏移地址。

eg.如果SS=6000H,说明堆栈段起始物理地址是_____60000H___。

已知字节(00018H)=14H,字节(00017H)=20H,则字(00017H)为__1420H______。

如果(SI)=0088H,(DS)=5570H,对于物理地址为55788H的内存字单元,其内容为0235H,对于物理地址为5578AH的内存字单元,其内容为0E60H,那么执行指令LDS SI,[SI]以后,(SI)= 0235H ,(DS)= 0E60H .第三章80x86的指令系统和寻址方式与数据有关的寻址方式(立即寻址方式,寄存器寻址方式,直接寻址方式,寄存器间接寻址方式,寄存器相对寻址方式,基址变址寻址方式,相对基址变址寻址方式)和与转移地址有关的寻址方式(段内直接寻址,段内间接寻址,段间直接寻址,段间间接寻址)。

数据传送指令(通用数据传送指令、累加器专用传送指令、输入输出指令)、算术指令(加法指令、减法指令(*加减指令对4个标志位的影响[of,cf,sf,zf])、乘法指令(*乘法指令的要求:目的操作数必须是累加器)、除法指令(*被除数在累加器中,除法指令执行完以后,商和余数在?))、逻辑指令(逻辑运算指令(*XOR,AND,OR,TEST指令及指令执行后对标志位的影响)、移位指令)、串处理指令(与REP相配合工作的MOVS、STOS、LODS 指令,与REPE/REPZ和REPNE/REPNZ联合工作的CMPS、SCAS指令)、控制转移指令(无条件转移指令、条件转移指令、循环指令、子程序调用指令、中断)。

汇编语言课件第05章

汇编语言课件第05章

11/37
第五章 汇编语言顺序程序设计
乘法指令只影响CF和 , 乘法指令只影响 和OF,其它条件码无定义 。 1)MUL: 若乘积的高一半为 ,则CF=OF=0, ) : 若乘积的高一半为0 , 否则, 否则,CF=OF=1。 。 2)IMUL:若乘积的高一半是低一半的符号位的扩展, 2)IMUL:若乘积的高一半是低一半的符号位的扩展, 则,CF=OF=0,否则,CF=OF=1。 ,否则, 。
13/37
第五章 汇编语言顺序程序设计
一、算术指令(5类) 算术指令( 类 1. 加法指令(ADD,ADC,INC) 加法指令( , , ) 2. 减法指令(SUB,SBB,DEC,NEG ,CMP ) 减法指令( , , , 3.乘法指令 MUL,IMUL) 3.乘法指令(MUL,IMUL) 乘法指令( 4.除法指令(DIV,IDIV) 除法指令( 除法指令 , ) 5.十进制调整指令(DAA,DAS等) 十进制调整指令( 十进制调整指令 , 等
12/37
第五章 汇编语言顺序程序设计
如何区分MUL和IMUL 和 如何区分 (1111,1111B)×(1111,1111B) , ) , ) 看作无数号数,上式为: 看作无数号数,上式为:FFH×FFH=FFE01H × 看作带符号数,上式为:(-1) 看作带符号数,上式为:( )×(-1)=1 :( ) 选用MUL或IMUL应根据实际情况而定。 或 应根据实际情况而定。 选用 应根据实际情况而定
21/37
第五章 汇编语言顺序程序设计
本章内容分三节: 本章内容分三节: 5.1 算术指令 5.2 逻辑指令 5.3 顺序程序举例
22/37
第五章 汇编语言顺序程序设计
二、逻辑指令 逻辑运算指令( 1. 逻辑运算指令(5个) 移位指令( 2. 移位指令(8个)

DSP技术及应用--陈金鹰(第五章)

DSP技术及应用--陈金鹰(第五章)
10
start:STM STM STM RPT MVPD STM STM RPT MVDD end: B .end
#0,SWWSR ;复位SWWSR #STACK+30H,SP;初始化堆指针 #x,AR1 ;将目的地首地址赋给AR1 #9 ;设定重复传送的次数为10次 table,*AR1+ ;程序存储器传送到数 ;据存储器 #x,AR2 ;将x的首地址存入AR2 #y,AR3 ;将y的首地址存入AR3 #9 ;设置重复执行10次下条指令 *AR2+,*AR3+;将地址x开始的10个值 ;复制到地址y开始的10个单元 end
并行存储和加/减法 指令
ST ‖ADD
src, Ymem Xmem, dst

Ymem=src>> ( 16-ASM ) dst=dst+Xmem
18
例5-10 编写计算z=x+y和f=d+e的程序段。 在此程序段中用到了并行存储/加载指令,即在同一机器周期 内 利 用 E 总 线 存 储 和 D 总 线 加 载 。 数据存储器分配如图5-4所示。 .title “cjy3.asm” .mmregs STACK .usect “STACK”,10H .bss x,3 ;为第一组变量 ;分配3个存储单元 .bss d,3 ;为第二组变量 ;分配3个存储单元 .def start .data table: .word 0123H,1027H,0,1020H,0345H,0
16
6.并行运算
(1)并行运算指同时利用D总线和E总线。 其中,D总线用来执行加载或算术运算,E总 线用来存放先前的结果。 (2)并行指令都是单字单周期指令。 (3)并行运算时所存储的是前面的运算结 果,存储之后再进行加载或算术运算。 (4)并行指令都工作在累加器的高位。 (5)大多数并行运算指令都受累加器移位 方式ASM位影响。

汇编语言程序设计课后答案

汇编语言程序设计课后答案

汇编语言程序设计课后答案2.1(1)AX=1200h(2)AX=0100h(3)AX=4C2Ah(4)AX=3412h(5)AX=4C2Ah(6)AX=7856h(7)AX=65B7h2.2(1) 两操作数类型不匹配(2) IP指令指针禁止用户访问(3) 立即数不允许传给段寄存器(4) 段寄存器之间不允许传送(5) 两操作数类型不匹配(6) 目的操作数应为[ BP ](7) 源操作数应为[BX+DI](8) 立即数不能作目的操作数2.3lea bx,table ;获取table的首地址,BX=200Hmov al,8 ;传送欲转换的数字,AL=8xlat ;转换为格雷码,AL=12H2.4mov ax,8057hpush axmov ax,0f79hpush axpop bx ;bx=0f79hpop [bx] ;DS:[0f79h]=8057h2.6AL=89h CF ZF SF OFPFAL=12h 1 0 0 11AL=0afh 0 0 1 01AL=0afh 1 0 1 01AL=00h 0 1 0 01AL=0ffh 0 0 1 01AL=00h 0 1 0 0 1堆栈是一种按“先进后出”原则存取数据的存储区域。

堆栈的两种基本操作是压栈和出栈,对应的指令是PUSH和POP。

2.52.7 W=X+Y+24-Z2.8(1)ADD DX,BX(2)ADD AL,[BX+SI](3)ADD [BX+0B2H],CX(4)ADD WORD PTR [0520H],3412H(5)ADD AL,0A0H2.9;为了避免与操作数地址混淆,将题中X,Y,Z,V 字操作数改为A,B,C,Dmov ax,X ;ax=Aimul Y ;dx,ax = A*B (将操作数看作符号数,以下同)mov cx,axmov bx,dx ;bx,ax <-- dx,ax =A*Bmov ax,Z ;ax = Ccwd ;dx,ax =C (扩展符号后为双字)add cx,axadc bx,dx ;bx,cx <--bx,cx+dx,ax=A*B+Csub cx,540sbb bx,0 ;bx,cx<--A*B+C-540mov ax, V ;ax= Dcwd ;dx,ax= D (扩展符号后为双字)sub ax, cxsbb dx, bx ;dx,ax = dx,ax - bx,cx = D-(A*B+C-540)idiv X ;运算结果:[D-(A*B+C-540h)]/A ;ax存商,dx存余数2.10;(1)xchg的操作数不能是立即数(2不能对CS直接赋值(3)两个操作数不能都是存储单元(4)堆栈的操作数不能是字节量(5)adc的操作数不能是段寄存器(6)没有确定是字节还是字操作(7)in不支持超过FFH的直接寻址(8)out只能以AL/AX为源操作数第二章(02)2. 其他逻辑指令使CF=OF=0, 根据结果影响其他标志位。

新版汇编语言程序设计习题答案(钱晓捷主编)

新版汇编语言程序设计习题答案(钱晓捷主编)

新版汇编语言程序设计习题答案(钱晓捷主编)第一章汇编语言基础知识1.1、简述计算机系统的硬件组成及各部分作用1.2、明确下列概念或符号:主存和辅存,RAM和ROM,存储器地址和I/O端口,KB、MB、GB和TB1.3、什么是汇编语言源程序、汇编程序、目标程序?1.4、汇编语言与高级语言相比有什么优缺点?1.5、将下列十六进制数转换为二进制和十进制表示(1)FFH (2)0H (3)5EH (4)EFH(5)2EH (6)10H (7)1FH (8)ABH1.6、将下列十进制数转换为BCD码表示(1)12 (2)24 (3)68 (4)127(5)128 (6)255 (7)1234 (8)24581.7、将下列BCD码转换为十进制数(1)10010001 (2)10001001 (3)00110110 (4)10010000(5)00001000 (6)10010111 (7)10000001 (8)000000101.8、将下列十进制数分别用8位二进制数的原码、反码和补码表示(1)0 (2)-127 (3)127 (4)-57(5)126 (6)-126 (7)-128 (8)681.9、完成下列二进制数的运算(1)1011+1001 (2)1011-1001 (3)1011×1001 (4)10111000÷1001(5)1011 ∧~1011 (8)1011 ⊕1001 1001(6)1011 ∨1001(7)1.10 数码0~9、大写字母A~Z、小写字母a~z对应的ASCII码分别是多少?ASCII码为0dh、0ah对应的是什么字符?1.11、计算机中有一个“01100001”编码,如果把它认为是无符号数,它是10进制什么数?如果认为它是BCD码,则表示什么数?又如果它是某个ASCII码,则代表哪个字符?1.12、简述Intel 80x86系列微处理器在指令集方面的发展。

汇编语言程序设计教程(第二版)习题参考答案

汇编语言程序设计教程(第二版)习题参考答案

汇编语言程序设计教程(第二版)习题参考答案第1章计算机基础知识1.计算机的应用分哪几个方面,请举例说明书中未提到的领域的计算机应用。

科学计算、数据处理、计算机控制、计算机辅助设计、人工智能、企业管理、家用电器、网络应用。

书中未提及的如:远程教育、住宅小区控制、飞行系统控制与管理等。

2.简述计算机的发展过程,请查阅相关资料,列出微机的发展过程。

电子管、晶体管、集成电路、大规模集成电路以IBM为例,微机的发展:4004、8008、8080、8086/8088、80286、80386、80486、Pentium 系列3.计算机的字长是怎么定义的,试举例说明。

计算机能同时处理二进制信息的位宽定义为计算机的字长。

如8086能同时进行16位二进制数据的运算、存储和传输等操作,该机器的字长为16位。

4.汇编语言中的基本数据类型有哪些?数值型数据和非数值型数据。

非数值数据如字符、字符串、逻辑值等。

(1)7BCH=011110111100B=1980D(2)562Q=101110010B=370D(3)90D=01011010B=5AH(4)1110100.111B=164.7Q=74.EH30H~39H 41H~5AH 61H~7AH9.在汇编语言中,如何表示二进制、八进制、十进制和十六进制的数值?用相应进制的数值加上进制标记即可。

二进制用B,如10101010B八进制用Q,如437Q。

十进制用D或不用,如54D,或54。

十六进制用H,如27A8H10.完成下列二进制数的加减运算。

(1)10101010 + 11110000 (2)11001100 + 01010100=110011010 =100100000(3)11011010 - 01010010 (4)11101110 - 01001101=10001000 =1010000111.完成下列十六进制数的加减运算。

(1)0FEA9 - 8888=7621H (2)0FFFF - 1234=EDCBH(3)0EAC0 + 0028=EAE8H (4)3ABC + 1678=5134H12.完成下列BCD码的运算。

汇编语言基础手册

汇编语言基础手册

汇编语言基础手册第一章概述汇编语言是一种低级语言,用于直接操作计算机硬件。

本手册将介绍汇编语言的基础知识和常用指令,帮助读者快速入门汇编语言编程。

第二章寄存器寄存器是汇编语言中最基本的数据存储单元,用于存储和处理数据。

本章将介绍汇编语言中常用的通用寄存器、段寄存器和特殊寄存器,并讲解它们的用途和操作方法。

第三章指令汇编语言的指令是用于完成各种操作的命令,例如数据传送、运算和控制等。

本章将详细介绍常用的数据传送指令、算术指令和逻辑指令,并提供相关的示例代码,帮助读者理解和应用。

第四章内存操作汇编语言中,内存是用于存储数据和指令的重要部分。

本章将介绍如何使用汇编语言进行内存的读取、写入和操作,并提供实际案例来演示内存操作的应用。

第五章程序控制程序控制是汇编语言中的核心内容,用于控制程序的流程和执行顺序。

本章将详细介绍条件转移、循环和子程序等程序控制结构,并提供实例代码以及相应的调试技巧。

第六章 I/O操作汇编语言可以通过输入和输出操作与外部设备进行通信。

本章将介绍如何使用汇编语言进行键盘输入和屏幕输出,并提供相应的示例代码和调试方法,使读者能够灵活运用I/O操作。

第七章常见问题与调试技巧本章将列举一些常见的汇编语言编程问题,并给出相应的解决方案和调试技巧。

读者可以通过学习这些问题和技巧,提高自己的编程能力和问题排除能力。

第八章汇编语言应用本章将介绍汇编语言在实际应用中的一些常见场景,包括操作系统开发、驱动程序编写和嵌入式系统设计等。

读者可以了解到汇编语言的实际用途,并借鉴相关案例来进行实际项目开发。

结语汇编语言是一门重要而底层的编程语言,对于理解计算机系统和进行系统级编程具有重要意义。

通过学习本手册,读者可以掌握汇编语言的基础知识和编程技巧,为进一步深入学习和应用打下坚实基础。

注:本手册基于x86架构进行讲解,部分指令和操作可能在其他架构中有所不同。

读者在实际应用中应结合具体环境和需求进行相应调整和学习。

CH5M-新概念汇编语言-杨季文-清华大学出版社

CH5M-新概念汇编语言-杨季文-清华大学出版社

演示!
;y = n/8
;sum = y + x*8
VC2010的编译器相当“聪明”。 不仅用寄存器作为局部变量,而且还充分利用 IA-32系列处理器的相关指令。 这样的目标代码在“时空”两个方面都是高效的。
ASM YJW
5.4.1 关于程序优化
➢关于优化
✓ 用寄存器作为局部变量能大大提高效率 • 寄存器位于CPU内部,存取寄存器速度最快; • 表示寄存器的编码比较短,相应指令的长度也就比 较短。
xor ecx, ecx
;33 C9
inc ecx xor eax, eax
;41 ;33 C0 mov ecx,1
cmp DWORD PTR _n$[ebp], ecx
jl SHORT LN1@cf37 LL3@cf37:
mov eax,0
add eax, ecx
;03 C1
inc ecx
;41
cmp ecx, DWORD PTR _n$[ebp]
;x = n
mov ecx, eax shr ecx, 3
;y = x 移位指令代替除法指;y令= n/8
lea eax, DWORD PTR [ecx+eax*8] ;sum = y + x*8
pop ebp
ret
乘法、加法,合并进行
cf520 ENDP
ASM YJW
5.4.1 关于程序优化
➢演示函数cf520的目标代码(另一种)
ASM YJW
5.4.1 关于程序优化
➢演示函数cf520的目标代码
演示VC编译器的优化工作
速度最大化 大小最小化
_n$ = 8
cf520 PROC
  1. 1、下载文档前请自行甄别文档内容的完整性,平台不提供额外的编辑、内容补充、找答案等附加服务。
  2. 2、"仅部分预览"的文档,不可在线预览部分如存在完整性等问题,可反馈申请退款(可完整预览的文档不适用该条件!)。
  3. 3、如文档侵犯您的权益,请联系客服反馈,我们会尽快为您处理(人工客服工作时间:9:00-18:30)。

2012-8-12
14
数据段定义如下:
DATA STRING DATA
SEGMENT DB ENDS
‘HOW ARE YOU!’,0
2012-8-12
15
CODE START: AGAIN:
NEXT:
SEGMENT ASSUME MOV MOV MOV MOV OR JZ CMP JB CMP JA OR MOV INC JMP
2012-8-12
10
数据段定义如下:
DATA ADDR NUMBER COUNT DATA
SEGMENT DW NUMBER DW Y DW ? ENDS
2012-8-12
11
CODE
START: MOV
REPEAT:
SHIFT: EXIT: CODE
SEGMENT ASSUME CS:CODE,DS:DATA AX,DATA MOV DS,AX MOV DX,0 MOV CX,16 MOV BX, ADDR MOV AX,[BX] TEST AX,0FFFFH JNS SHIFT INC DX SHL AX,1 LOOP REPEAT MOV COUNT,DX MOV AH,4CH INT 21H ENDS END START
2012-8-12 5
ห้องสมุดไป่ตู้
MOV INT AND CMP JB CMP JA SUB XOR ADD MOV JMP …. OK: MOV INT COMA:….. JMP ….. COMH:…. JMP
AH,1 21H AL,11011111B AL,’A’ OK AL,’H’ OK AL,’A’ AH,AH AX,AX BX,AX COMTAB[BX] AH,4CH 21H OK
CODE
START: MOV
REPEAT:
SHIFT:
EXIT:
CODE
SEGMENT ASSUME CS:CODE,DS:DATA AX,DATA MOV DS,AX MOV CX,0 MOV BX, ADDR MOV AX,[BX] TEST AX,0FFFFH JZ EXIT JNS SHIFT INC CX SHL AX,1 JMP REPEAT MOV COUNT,CX MOV AH,4CH INT 21H ENDS END START
OK
5.2 循环程序设计
循环由四部分组成:初始化部分,循环体部分, 调整部分,控制部分。
2012-8-12
9
例:在ADDR单元中存放着数Y的地址,试编制一 程序把Y中1的个数存入COUNT单元中。 分析: 1.测试Y中1的个数,采用逐位测试方法,用移位 的方法把各位数逐次移到最高位,根据最高位 是否为1来计数。 2.循环结束方法: 1)计数值为16,作为结束 2)测试数是否为0
第5章 循环与分支程序设计
本章重点: 分支结构程序设计 循环结构程序设计 本章作业: P193 5.1 5.6 5.11
2012-8-12
1
5.1 分支程序设计
单个条件分支:IF语句和IF-ELSE语句,利用 条件测试指令和条件转移指令实现。 开关条件分支:SWITCH语句,利用地址表实现。
2012-8-12
例:写程序把一个字符串中的所有的大写字母转 换为小写字母,设字符串以0结尾。 分析: 1.判断是否大小写字母,比较字母ASCII码。 2.A—Z的ASCII码:41H—5AH a----z的ASCII码:61H----7AH 转换方法:大写ASCII码+20H 3.循环次数不确定,以结束符作为循环结束条件
CS:CODE,DS:DATA AX,DATA DS,AX SI,OFFSET STRING AL,[SI] AL,AL OK AL,’A’ NEXT AL,’Z’ NEXT AL,20H [SI],AL SI AGAIN
OK:
CODE
MOV INT ENDS END
AH,4CH 21H
START
LAB1: LAB2:
CODE
MOV AND CMP JA ADD JMP ADD MOV
AL,XX AL,0FH AL,9 LAB1 AL,30H LAB2 AL,37H ASCII,AL
MOV AH,4CH INT 21H ENDS END START
例:设程序每次接收一个单键命令A至H,然后 根据命令进行相应处理。否则不处理。 分析: 1.这是一个多分支选择结构,如果用C语言实现为 程序 2.汇编语言实现多分支选择结构,多采用地址表 的方法,实现安排一张入口地址表,存放入口 地址的偏移地址。见程序段。
2
例:实现把一位十六进制数转换为对应ASCII码 的程序。 分析:对应关系
X+30H(0<=X <=9)
Y=
X+37H(0AH<=X<=0FH)
2012-8-12
3
DATA XX ASCII DATA CODE
START:
SEGMENT DB 4 DB ? ENDS SEGMENT ASSUME CS:CODE,DS:DATA MOV AX,DATA MOV DS,AX
相关文档
最新文档