汇编语言第五章答案
第5章习题解答

第5章汇编语言程序设计习题参考答案1.(1) BUFF DB 240 DUP(?)(2) xx DB “BYTE”,”WORD”2.:0000H,则内存分配如下:V AR1V AR2V AR3V AR4V AR53.(1) 段的类型:段的类型有4种,分别是代码段、数据段、堆栈段和附加段。
(2) 段的定义:定义段使用伪指令SEGMENT/ENDS来定义的。
即:段名SEGMENT [定位类型] [组合类型] […类别‟]……段名ENDS(3) 选项的作用和含义:定位类型:告诉汇编程序如何确定逻辑段的边界在存储器的位置,共有4种。
①BYTE:表示逻辑段从字节的边界开始,即本段的起始地址紧接前一段。
②WORD:表示逻辑段从字的边界开始,即本段的起始地址必须是偶数。
③PARA:表示逻辑段从节的边界开始,即本段的起始地址后4位为0。
④PAGE:表示逻辑段从节的边界开始,即本段的起始地址后8位为0。
组合类型:告诉汇编程序当装入存储器时各个逻辑段如何进行组合,共有6种。
①不组合:如果缺省,则不组合。
② PUBLIC:对于不同逻辑段只要有相同段名就把他们集中成一段装入内存。
③ STACK:同PUBLIC相同,但仅限于堆栈段。
④ COMMON:对于不同逻辑段若有相同的段名,则都从同一地址装入。
⑤ MENORY:表示在几个逻辑段连接时,本段定位在地址最高的地方。
⑥ AT 表达式:表示以表达式的值来定位段地址。
‘类别’:在连接时决定各逻辑段的装入顺序。
4. 假设程序中有4个不同类型的段,则名为initprogram宏指令的宏定义如下:initprogram MACRO csname,dsname,esname,ssnameASSUME CS:csname,DS:dsname,ES:esname,SS:ssnameSTART: MOV AX,dsnameMOV DS,AXMOV AX,esnameMOV ES,AXMOV AX,ssnameMOV SS,AXENDM5.假设需传送的数据块为字节数据块,则名为Datastranaction宏指令的宏定义如下:Datastranaction MACRO buffer1,buffer2,lengthLEA SI,buffer1LEA DI,buffer2MOV CX,lengthCLDREP MOVSBENDM6.有效地指令为:(2)、(5)、(9)无效的指令为:(1) 数据类型不一致(3) 两个操作数不能同时为存储器操作数(4) CS不能作为目的操作数(6) 不能用两个变址寄存器作有效地址分量(7) 一个操作数不能是两个变量名的表达式(8) 基址和变址只能相加不能相减(10) 目的操作数不能是立即数(11) 在有效地址中不能减基址或变址严格地说:(9)也不对,因为没有指出存储器的数据类型,即操作数类型不明确。
汇编语言程序设计_第5章 分支循环程序设计(参考答案)

第5章分支、循环程序设计本章要点: 转移指令的寻址方式及其执行过程,控制转移类指令的使用,分支和循环程序的设计和应用。
程序调试的方法,常见问题的程序设计方法。
一、单项选择题5.1.1条件转移是根据标志寄存器中的标志位来判断的,条件判断的标志位共有( B )位。
A. 4B. 5C. 6D. 95.1.2用一条条件转移指令一次可以实现( A )个分支。
A. 2B. 3C. 4D. N5.1.3 条件转移指令的转移范围是(A)。
A. -128~127B. 0~255C. 0~65535D. -32768~327675.1.4 设A为字变量,B为标号,下列指令中不正确的是(D)。
A. MOV AX,AB. JNZ BC. JMP [SI]D. JMP B[BX]5.1.5 下述指令中影响CF标志位的是(A)。
A. SHL AL,1B. MOV AL,1C. JC LD. JNC L5.1.6 下述指令中不影响CF标志位的是(A)。
A. INC SIB. SUB SI,0C. NEG ALD. TEST AL,15.1.7 在多重循环程序设计中,每次通过外层循环进入内层循环时,其内层循环的初始条件(B)。
A. 不必考虑B. 必须重新设置C. 必须清0D. 必须置15.1.8 当设计一个程序时,最重要的是(B)。
A. 程序的结构化B. 能使程序正常运行并实现功能C. 程序的执行速度快D. 程序占用的存储空间小*5.1.9 如果“JNC L”指令的操作码放在0040H,转移后在0020H处取下一指令的操作码,那么这条指令的位移量是(C)。
A. 1EHB. 20HC. 0DEHD. 0E0H*5.1.10 如果“JGE P”指令的操作码放在0050H,该指令的位移量是34H,执行完这条指令转移取下一条指令的偏移地址是(C)。
A. 82HB. 84HC. 86HD. 88H二、填空题5.2.1 当下面循环程序中的划线处填上一个什么数字时,执行的循环次数最多?MOV CX,____0______MOV AX,0L:INC AXLOOP L5.2.2 当两个数进行比较后,执行__JE L(JZ L)表示两数相等则转移到L。
汇编 第五章基本结构程序设计参考答案.ppt

BUF DW 16
NUM DW ?
DATA ENDS
CODE SEGMENT
ASSUME CS:CODE,DS:DATA
BEGIN:MOV AX,DATA
MOV DS, AX
MOV AX, [BX]
MOV BX , OFFSET AQTAB
MOV NUM , AX
MOV AX, BUF
INC BUF2
DATA ENDS
JMP EXIT
CODE SEGMENT
JIAOHUAN:MOV BUF1,BL
ASSUME DS:DATA
MOV BUF2,AL
ASSUME CS:CODE
EXIT: MOV AH,4CH
START:MOV AX,DATA
INT 21H
MOV DS,AX
MOV SI,OFFSET BUF
MOV CX, CNT
MOV AX, 0
MOV SUM, AL
MOV AH, 4CH
INT 21H
CODE ENDS
END START
P102_58
DATA SEGMENT
X DW -123
Y DW 50
Z DW 1234H
DATA ENDS
CODE SEGMENT
CODE ENDS
MOV AL,BUF1
END START
MOV BL,BUF2
TEST BL,01H
JZ EXIT ;BUF2中为偶数
TEST AL,01H
JZ JIAOHUAN
;BUF1中偶数,BUF2为奇数
P102_57
DATA SEGMENT
BUF DB 30H,02H,10H,11H,56H,78H,65H,54H,85H,19H
汇编第五章课后题答案

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中。
汇编语言课后答案第5章

第5章习题5.1 选择题1.条件转移指令能转移的最大范围是(A)A. –128~127B. 0~255C. -32768~32767D. 0~655352.指令JMP BX转移的目标地址的偏移量为(c)A. IP+BX的内容B. IP+[BX]C. BX的内容D. BX所指向的内存字单元的内容3.指令JMP WORD PTR [BX]转移的目标地址偏移量为(D)A. IP+BX的内容B. IP+[BX]C. BX的内容D. BX所指向的内存字单元的内容4.若A、B为无符号数,当A≥B时转移的条件转移指令为(D)A. JGEB. JGC. JAD. JAE5.若A、B为带符号数,当A≤B时转移的条件转移指令为(D)A. JBB. JBEC. JLD. JLE6.下列程序段中,不能转移到标号L1处执行的程序段是(B)A. JMP L1B. MOV BX,L1C. LEA BX,L1D. MOV BX,OFFSET L1 JMP BX JMP BX JMP BX7.下面程序段中,当满足条件,转移到标号L2执行时,BL中的值正确的是( D )CMP BL,2FHJGE L2A. BL=0FFHB. BL=80HC. BL=0D. BL=30H8. 设有下列程序段,若执行后能转移到L3处,则说明AL的内容为( A,D)TEST AL,05HJZ L3A. 0A0HB. 05HC. 第1、3位为0D. 第0、2位为05.2 内存缓冲区BUF1中有10个字节数据,下面的程序段求出这十个数的平均值,并存储于字节变量RESULT中,请将程序补充完整。
MOV AX,0LEA BX,BUF1MOV CX,10LOP1:ADD AX,___[BX]_____INC BX_LOOP LOP1_________MOV DL,10DIV DLMOV RESULT,__AL____HLT5.3 内存缓冲区BUF2中有10个无符号字数据,下面的程序段找出这些数的最大值,并存于MAX字单元。
新版汇编语言程序设计1-5章【课后答案】

新版汇编语言程序设计【课后习题答案】第1章汇编语言基础知识〔习题1.1〕简述计算机系统的硬件组成及各部分作用。
〔解答〕CPU:包括运算器、控制器和寄存器组。
运算器执行所有的算术和逻辑运算;控制器负责把指指令逐条从存储器中取出,经译码分析后向机器发出各种控制命令,并正确完成程序所要求的功能;寄存器组为处理单元提供所需要的数据。
存储器:是计算机的记忆部件,它用来存放程序以及程序中所涉及的数据。
外部设备:实现人机交换和机间的通信。
〔习题1.2〕明确下列概念或符号:主存和辅存,RAM和ROM,存储器地址和I/O端口,KB、MB、GB和TB〔解答〕主存又称内存是主存储器的简称,主存储器存放当前正在执行的程序和使用的数据,CPU 可以直接存取,它由半导体存储器芯片构成其成本高、容量小、但速度快。
辅存是辅助存储器的简称,辅存可用来长期保存大量程序和数据,CPU需要通过I/O接口访问,它由磁盘或光盘构成,其成本低、容量大,但速度慢。
RAM是随机存取存储器的英语简写,由于CPU可以从RAM读信息,也可以向RAM写入信息,所以RAM也被称为读写存储器,RAM型半导体存储器可以按地址随机读写,但这类存储器在断电后不能保存信息;而ROM中的信息只能被读出,不能被修改,ROM型半导体通常只能被读出,但这类存储器断电后能保存信息。
存储器由大量存储单元组成。
为了区别每个单元,我们将它们编号,于是,每个存储单元就有了一个存储地址,I/O接口是由一组寄存器组成,为了区别它们,各个寄存器进行了编号,形成I/O地址,通常称做I/O端口。
KB是千字节、MB是兆字节、GB是吉字节和TB是太字节,它们都是表示存储器存储单元的单位。
〔习题1.3〕什么是汇编语言源程序、汇编程序、目标程序?〔解答〕用汇编语言书写的程序就称为汇编语言源程序;完成汇编工作的程序就是汇编程序;由汇编程序编译通过的程序就是目标程序。
〔习题1.4〕汇编语言与高级语言相比有什么优缺点?〔解答〕汇编语言与高级语言相比的优点:由于汇编语言本质就是机器语言,它可以直接地、有效地控制计算机硬件,因而容易产生运行速度快,指令序列短小的高效目标程序,可以直接控制计算机硬件部件,可以编写在“时间”和“空间”两方面最有效的程序。
汇编语言 廖建明编 课后习题第五章习题答案

5.1 顺序分支循环5.2 (AX)=5400H (BL)=06H (DX)=2106H5.3 D5.4 C5.5 B5.6 D5.7 C5.8 0FFH 05.9 C5.10 略5.11 B5.12 A5.13 23H 01H 56H 04H 00H5.14 将BUF里的小写字母转换成大写字母5.15 略5.16 (1)完成85274AH与938765H的加法功能(2)不能。
INC对CF无影响,而ADD有影响(3)MOV SI,OFFSET DA TA1(4)置CF为零。
若CF初始为1,则在第一次执行ADC指令时会产生不正确的结果。
5.17(编程题为参考答案,下同)DA TA SEGMENTDA TA1 DB ?DA TA2 DB ?DA TA ENDSCODE SEGMENTASSUME CS:CODE,DS:DA TABEGIN:MOV AX,DA TAMOV DS,AXMOV DX,DA TA1;高位送DXMOV AX,DA TA2;低位送AXSHL AX,1;RCL DX,1;MOV AH,4CHINT 21HCODE ENDSEND BEGIN5.18DA TA SEGMENTDA TAS DB ‘PLEAST INPUT:’,0DH,0AH, ‘$’DA TA ENDSCODE SEGMENTASSUME CS:CODE,DS:DA TABEGIN: MOV AX,DA TAMOV DS,AXMOV AH,9HINT 21H ;输出“PLEASE INPUT:”MOV AH,1INT 21H ;用户输入MOV DL,ALSUB DL,20HMOV AH,2INT 21H ;显示输出MOV AH,4CHINT 21HCODE ENDSEND BEGIN5.19DA TA SEGMENTARRAY DB 20 DUP(?);原数列PLUS DB 20 DUP(0);存放正数NEGA DB 20 DUP(0);存放负数PLUS_N DB 0;指示正数个数NEGA_N DB 0;指示负数个数TIME DB 20DA TA ENDSCODE SEGMENTASSUME CS:CODE,DS:DA TABEGIN: MOV AX,DA TAMOV DS,AXLEA SI,ARRAYLEA BX,PLUSLEA DI,NEGAMOV CX,TIMECLC;以上为初始化LOOP1: MOV AL,[SI]CMP AL,0INC SIJA DAYUJB XIAOLOOP LOOP1;等于零处理JMP SHOWDAYU: MOV [BX],AL;大于零的处理INC BXINC PLUS_NLOOP LOOP1JMP SHOWXIAOYU:MOV [DI],AL;小于零的处理INC DIINC NEGA_NLOOP LOOP1SHOW: MOV DL,PLUS_N;屏幕显示输出MOV AH,2INT 21HMOV DL,NEGA_NMOV AH,2INT 21HMOV AH,4CHINT 21HCODE ENDSEND BEGIN5.20STACK SEGMENT PARA STACKDB 10H DUP(0)STACK ENDSCODE SEGMENTASSUME CS:CODE,SS:STACKBEGIN: PUSHF;标志位入压入栈POP AX;出栈到AXEXCHANGE AH,AL;高低位互换PUSH AX;AX压入栈POPF;弹出到标志寄存器CODE ENDSEND BEGIN5.21DA TA SEGMENTSTR DB ‘INPUT 1 OR 0’,0DH,0AH,‘$’BUFF DB 20 DUP(0)LEN DW 10DA TA ENDSCODE SEGMENTASSUME CS:CODE,DS:DA TABEGIN: MOV AX,DA TAMOV DS,AXMOV DX,OFFSET STRMOV AH,09HINT 21HMOV BH,48;零的ASCII码MOV BL,65;A的ASCII码LEA SI,BUFFMOV CX,LENMOV AH,1HINT 21HCMP DL,1JZ ACMP DL,2JZ BJMP END0;输入非1非2即结束程序A: MOV [SI],BHINC SIMOV [SI],BLINT SIMOV DL,BHMOV AH,2INT 21HMOV DL,BLMOV AH,2INT 21HINC BHINC BLLOOP AJMP END0B: MOV [SI],BLINC SIMOV [SI],BHINC SIMOV DL,BLMOV AH,2INT 21HMOV DL,BHMOV AH,2INT 21 HINC BLINT BHLOOP BEND0: MOV AH,4CHINT 21HCODE ENDSEND BEGIN5.22DA TA SEGMENTX DB ?Y DB ?Z DB ?SUM DB 0DA TA ENDSCODE SEGMENTASSUME CS:CODE,DS:DA TA BEGIN: MOV AX,DA TAMOV DS,AXMOV AX,XADD AX,YCMP AX,200MOV AX,XJG SUB0;判断ADD AX,ZJMP END0SUB0: SUB AX,ZEND0: MOV SUM AXMOV AH,4CHINT 21HCODE ENDSEND BEGIN5.23略。
汇编语言程序设计实验指导及习题解答-第五章

DW 1,2,3,4,5,6,7,8,9,10 DW($-ARY1)/2 DW ? DW 10,20,30,40,50,60,70,80 DW($-ARY2)/2 DW ? DW 100,200,300,400,500,600 DW($-ARY3)/2 DW ?
;构造数组 1 的地址表
97
;通过寄存器传递地址表的首地址
;通过寄存器传递地址表的首地址 ;求和数组 2 并保存结果 ;构造数组 3 的地址表
MOV TABLE+2,OFFSET COUNT3 MOV TABLE+4,OFFSET SUM3 LEA BX,TABLE CALL ARY-SUM MOV AX, 4C00H INT 21H ARY-SUM PROC NEAR PUSH AX PUSH PUSH PUSH MOV MOV MOV MOV XOR ADD ADD CX SI DI SI,[BX] DI,[BX+2] CX,[DI] DI,[BX+4] AX,AX AX,[SI] SI,2
TRAN
;分离出个位数 ;分离出十位数
MOV ROR MOV MUL ADD
CL,04H AL,CL BH,0AH BH AL,BL
;将十位数移至低 4 位 ;十位数乘以 10 ;乘积与个位数相加
TRAN
POP CX POP BX POPF RET ENDP END START
2.通过地址表传递参数地址 有时直接传递参数本身不能方便地实现所要求功能,需要通过地址表传递参数地址的 方法实现参数传递。具体方法是先建立一个地址表,该表由参数地址构成。然后把表的首 地址通过寄存器或堆栈传递给子程序。 【例 5.4】 计算 ARY1、ARY2、ARY3 三个数组和,并把各自的和分别放入 SUM1、 SUM2、SUM3 单元,其数组元素及结果均为字型数据。 显然数组求和应该用子程序完成,这样做使得代码真正共享。但在子程序中不能直接 引用数组变量名,否则不能做到通用,在这种情况下可以通过传递参数地址的方法实现最 终的参数传递。本例用数组首地址、元素个数的地址、结果地址构成一个地址表,通过寄 存器把表的首地址传递给子程序,子程序通过地址表的参数地址访问到所需参数。
汇编语言第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章 习题及答案

第五章 汇编语言程序设计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.1无符号数: 11010011=211=D3H,01110111=119=77H,10000011=131=83H,00101111=47=2FH,10101010=170=AAH带符号数:11010011= -45=D3H,01110111=+119=77H,10000011= -125=83H,00101111=+47=2FH,10101010= -86=AAH1.2 5E8AH,0BE6H,3DEH,4940H1.3 00011101+00110101=01010010=52H=8201001001+11101000=00110001=31H=4910111110+01010010=00010000=10H=1610011010+11110001=10001011=8BH= -1171.4 00101001+01010011=01111100+00000110=10000010=82H=8201110011-00100100=01001111-00000110=01001001=49H=4901100110+00011000=01111110+00000110=10000100=84H=840000000100110010+01110101=0000000110100111+00000110=0000001000000111=0207H=2071.5 000020A3H,FF94H,00003456H,007FH,FFFFEC00H1.6无符号数:0~65535,0000H~FFFFH;带符号数:-32768~+32767,8000H~7FFFH 1.7 (1) 38H等于十进制数56,是十进制数56的补码,数字8的ASCII码,十进制数38的压缩BCD码(2) FFH等于十进制数-1,是带符号数-1的补码,无符号数为255(3) 5AH等于十进制数90,是十进制数90的补码,大写字母Z的ASCII码(4) 0DH等于十进制数13,是十进制数13的补码,回车符的ASCII码1.8(1) 108=01101100B=6CH,补码01101100B,压缩BCD码0000000100001000,ASCII码313038H(2) 46=00101110B=2EH,补码00101110B,压缩BCD码01000110,ASCII码3436H(3) –15=11110001B=F1H,补码11110001B,ASCII码2D3135H(4) 254=0000000011111110B=00FEH,补码0000000011111110B,压缩BCD码0000001001010100,ASCII码323534H1.9(1) 56+63=01110111B,CF=0,SF=0,ZF=0,OF=0(2) 83-45=00100110B,CF=0,SF=0,ZF=0,OF=0(3) -74+29=11010011B,CF=0,SF=1,ZF=0,OF=0(4) -92-37=01111111B,CF=1,SF=0,ZF=0,OF=11.10回车、换行、响铃、ESC键、空格键、@、P、p习题二答案:2.9最少划分为16个逻辑段,最多划分为65536个逻辑段(每段16个字节)2.10CS:IP,DS:BX、SI、DI,ES:BX、SI、DI,SS:SP、BP2.11字节单元保存8位数,字单元保存16位数。
第5章汇编语言层习题参考解答-汇编语言与计算机组成原理 答案

.STACK 100H .CODE START: MOV AX, @DATA
MOV DS, AX XOR AH,AH MOV AL,SCORE SUB AL,60 MOV BL,10
L1: L2: L3: L4: L5: NEXT:
DIV BL MOV BL,AL XOR BH,BH SHL BX,1 JMP J_TAB[BX] MOV DX,OFFSET B MOV AH,9 INT 21H JMP NEXT MOV DX,OFFSET BPL MOV AH,9 INT 21H JMP NEXT MOV DX,OFFSET AM MOV AH,9 INT 21H JMP NEXT MOV DX,OFFSET A MOV AH,9 INT 21H JMP NEXT MOV DX,OFFSET AP MOV AH,9 INT 21H JMP NEXT MOV AH, 4CH INT 21H END START
.MODEL SMALL .DATA SCORE BYTE 60 AP BYTE 'A+','$' A BYTE 'A','$' AM BYTE 'A-','$' BPL BYTE 'B+','$' B BYTE 'B','$' J_TAB WORD L1,L2,L3,L4,L5 .CODE START: MOV AX, @DATA
最新汇编语言程序设计(第四版)第5章【课后答案】

汇编语言程序设计第四版【课后习题答案】第五章高级汇编语言程序设计5. 1条件表达式中逻辑与“ &&表示两者都为真,整个条件才为真,段:.if (X==5) && (ax!=bx)inc ax・endif请用转移指令实现上述分支结构,并比较汇编程序生成的代码序列。
解:cmp X, 5je abcjmp doneabc: cmp ax, bxjne cdejmp donecde: inc axdone:…・5. 2条件表达式中逻辑与表示两者之一为真,整个条件就为真,.if (X==5) || (ax!=bx)inc ax・endif请用转移指令实现上述分支结构,并比较汇编程序生成的代码序列O解cmp X, 5je abcjmp donecmp ax, bxjne abcjmp doneabc: inc axdone:....5.3、对于程序段:.while ax!=10对于程序对于程序段:mov [bx],axinc bxinc bxinc ax.endw请用处理器指令实现上述循环结构,并比较汇编程序生成的代码序列。
5.4、对于程序段:・ repeatmov [bx] ,axinc bxinc bxinc ax■until ax=10请用处理器指令实现上述循环结构,并比较汇编程序生成的代码序列。
5.5、宏是如何定义、调用和展开的?解:宏定义采用一对伪指令实现,格式如下(其中方括号表示可选):宏名macro [形参表]宏定义体endm宏调用时,利用宏名带上实参即可,格式如下:宏名[实参表]5.6、宏定义中的形式参数有什么特点,它是如何进行形参和实参结合的?解:宏的参数功能非常强大,即可以没有参数,也可以带有一个或多个参数;而且参数的形式非常灵活,可以是常量、变量、存储单元、指令或它们的一部分,还可以是表达式等。
宏展开时的形参与实参结合是用位置匹配的实参对形参进行取代。
实参个数与形参个数不同时,多余的实参没有作用,缺少的实参则用空格代替。
16/32位微机原理、汇编语言及接口技术第2版-第五章-习题答案

P151第五章部分习题参考答案
5.2 答:随机存取存储器丢失只读存储器读取不丢失8 13 8
5.4 答:应该有12个地址引脚和4个数据引脚。
需安排的控制引脚有:片选CS,读控制OE,写控制WE。
5.5 答:位片结构结构是每片有1位数据线;字片结构是每片有多位数据线。
2114是字片结构,4116是位片结构。
5.7 答:用多个芯片来扩充存储数据的位宽度,这种扩充称为位扩充。
用多个芯片在地址方向上进行扩充,这种扩充称为字扩充。
用2114(1K*4)组成32KB需64片,用4116(16K*1)组成32KB需16片。
5.9 答:每个存储单元会同时拥有16个地址。
5.10 答:
5.11 答:
5.12 答:
5.13 答:2764 8K*8 EPROM 片内A 12—A 0 32KB 空间 使用4片,因为存储空间在8088系统地址最高端的32KB ,所以地址范围为 F8000H —FFFFFH
+5V
D 7-D 0
A 19
A 16A 17A 18。
最新汇编语言程序设计(第四版)第5章【课后答案】

汇编语言程序设计第四版【课后习题答案】--囮裑為檤第五章高级汇编语言程序设计5.1 条件表达式中逻辑与“&&”表示两者都为真,整个条件才为真,对于程序段:.if (X==5) && (ax!=bx)inc ax.endif请用转移指令实现上述分支结构,并比较汇编程序生成的代码序列。
解:cmp X, 5je abcjmp doneabc: cmp ax, bxjne cdejmp donecde: inc axdone:....5.2条件表达式中逻辑与“||”表示两者之一为真,整个条件就为真,对于程序段:.if (X==5) || (ax!=bx)inc ax.endif请用转移指令实现上述分支结构,并比较汇编程序生成的代码序列。
解:cmp X, 5je abcjmp donecmp ax, bxjne abcjmp doneabc: inc axdone: ....5.3、对于程序段:.while ax!=10mov [bx],axinc bxinc bxinc ax请用处理器指令实现上述循环结构,并比较汇编程序生成的代码序列。
5.4、对于程序段:.repeatmov [bx],axinc bxinc bxinc ax请用处理器指令实现上述循环结构,并比较汇编程序生成的代码序列。
5.5、宏是如何定义、调用和展开的?解:宏定义采用一对伪指令实现,格式如下(其中方括号表示可选):宏名macro [形参表]宏定义体endm宏调用时,利用宏名带上实参即可,格式如下:宏名[实参表]5.6、宏定义中的形式参数有什么特点,它是如何进行形参和实参结合的?解:宏的参数功能非常强大,即可以没有参数,也可以带有一个或多个参数;而且参数的形式非常灵活,可以是常量、变量、存储单元、指令或它们的一部分,还可以是表达式等。
宏展开时的形参与实参结合是用位置匹配的实参对形参进行取代。
实参个数与形参个数不同时,多余的实参没有作用,缺少的实参则用空格代替。
计算机汇编语言第四章第五章答案

本答案经本人简单作答、整理、修改(并是标准答案),仅供同学参考,欢迎同学提出宝贵意见。
4.10给定(BX)=637DH,(SI)=2A9BH,位移量D=7237H,试确定在以下各种寻址方式下的有效地址是什么答案:(1)立即寻址没有 IP的内容(2)直接寻址 7237H ;MOV AX,[7237H](3)使用BX的寄存器寻址没有 ;MOV AX,BX(4)使用BX的间接寻址 637DH ;MOV AX,[BX](5)使用BX的寄存器相对寻址 0D5B4H ;MOV AX,D[BX](6) 基址变址寻址 8E18H ;MOV AX,[BX][SI](7)相对基址变址 004FH ;MOV AX,D[BX][SI]4.11.求执行两条指令后,各标志位的状态MOV AL,91 ;执行后,(AL)=91=5BHADD AL,0BAH加法执行如下:0BA H 1011 1010+ 05B H 0101 1011115 H 1 0001 0101CF:显然最高位产生了进位(两个加数都是两位的,和却有三位),CF=1AF:低四位向高四位产生了进位(A+B产生进位),AF=1ZF:运算结果不为0,ZF=0SF:运算结果最高位为0(高四位:1H=0001B),SF=0OF:负+正=正(两个加数的符号位不同),没有溢出,OF=04-12(1)MOV AL,0F5H 正确(2)ADD [BX][BP],BX 错误,不能同时使用[BX][BP]进行寻址(3)CMP AL,100H 错误,AL为8位,100H大于8位,类型不匹配。
(4)TEST [BP],DL 正确(5)ADC 15,CL 错误,目的操作数不能是立即数(6)SUB [DI],DA_WORD 错误,两个操作数不能同时是存储器操作数。
(7)OR CH,CL 正确(8)MOV AL,1000H 错误,AL为8位,1000H为16位,类型不匹配。
(9)SAR 10H[DI],2 错误,AL为8位,移位多次必须CL中。
最新汇编语言程序设计(第四版)第5章【课后答案】

mov dx,calladdress
endif int 21h
ENDM
5.22; 1.编写主程序,并进行汇编产生OBJ模块;
2.编写独立的子程序,也进行汇编产生OBJ模块;
3.分别编写主程序与子程序时,需要处理好共用变量、过程、逻辑段属性、参 数传递等问题;
4.利用连接程序将主程序模块和子程序模块连接起来,形成完整的可执行程序5.28;;数据段table dw 2277,2138,1808,1709,1522,1356,1208,1139
movstr strN,dstr,sstr
lea si, sstr
lea di, dstr
mov cx, strN
1 pop ax
5.15; wtemp =2 repeat 100 dw 0
dw wtemp wtemp =wtemp+2
endm
5.18; DOS21H MACRO callnum,calladdress mov ah,callnum
5.7、宏结构和子程序在应用中有什么不同,如何选择采用何种结构?
解:宏汇编的特点是在汇编阶段进行语句展开,无需返回,不减少目标程序代 码,执行速度没有改变;通过形参、实参结合传递参数。宏汇编适合于程序段 较短或要求执行速度快的场合。
子程序在执行阶段需要由主程序执行调用指令CALL进行调用,进而转入子
mov [bx],ax
inc bx
inc bx
inc ax
■until ax=10
请用处理器指令实现上述循环结构,并比较汇编程序生成的代码序列。
5.5、宏是如何定义、调用和展开的?
解:
宏定义采用一对伪指令实现,格式如下(其中方括号表示可选):
汇编语言第五章答案

5.1试编写一个汇编语言程序,要求对键盘输入的小写字母用大写字母显示出来。
答:程序段如下:BEGIN:MOV AH,1;从键盘输入一个字符的DOS调用INT21HCMP AL,‘a’;输入字符<‘a’吗?JB STOPCMP AL,‘z’;输入字符>‘z’吗?JA STOPSUB AL,20H;转换为大写字母,用AND AL,11011111B也可MOV DL,AL;显示一个字符的DOS调用MOV AH,2INT21HJMP BEGINSTOP:RET5.2编写程序,从键盘接收一个小写字母,然后找出它的前导字符和后续字符,再按顺序显示这三个字符。
答:程序段如下:BEGIN:MOV AH,1;从键盘输入一个字符的DOS调用INT21HCMP AL,‘a’;输入字符<‘a’吗?JB STOPCMP AL,‘z’;输入字符>‘z’吗?JA STOPDEC AL;得到前导字符MOV DL,AL;准备显示三个字符MOV CX,3DISPLAY:MOV AH,2;显示一个字符的DOS调用INT21HINC DLLOOP DISPLAYSTOP:RET5.3将AX寄存器中的16位数分成4组,每组4位,然后把这四组数分别放在AL、BL、CL 和DL中。
答:程序段如下:DSEG SEGMENTSTORE DB4DUP(?)DSEG ENDS┇BEGIN:MOV CL,4;右移四次MOV CH,4;循环四次LEA BX,STOREA10:MOV DX,AXAND DX,0FH;取AX的低四位MOV[BX],DL;低四位存入STORE中INC BXSHR AX,CL;右移四次DEC CHJNZ A10;循环四次完了码?B10:MOV DL,STORE;四组数分别放在AL、BL、CL和DL中MOV CL,STORE+1MOV BL,STORE+2MOV AL,STORE+3STOP:RET5.4试编写一程序,要求比较两个字符串STRING1和STRING2所含字符是否完全相同,若相同则显示‘MATCH’,若不相同则显示‘NO MATCH’。
- 1、下载文档前请自行甄别文档内容的完整性,平台不提供额外的编辑、内容补充、找答案等附加服务。
- 2、"仅部分预览"的文档,不可在线预览部分如存在完整性等问题,可反馈申请退款(可完整预览的文档不适用该条件!)。
- 3、如文档侵犯您的权益,请联系客服反馈,我们会尽快为您处理(人工客服工作时间:9:00-18:30)。
5.1试编写一个汇编语言程序,要求对键盘输入的小写字母用大写字母显示出来。
答:程序段如下:BEGIN:MOV AH,1;从键盘输入一个字符的DOS调用INT21HCMP AL,‘a’;输入字符<‘a’吗?JB STOPCMP AL,‘z’;输入字符>‘z’吗?JA STOPSUB AL,20H;转换为大写字母,用AND AL,11011111B也可MOV DL,AL;显示一个字符的DOS调用MOV AH,2INT21HJMP BEGINSTOP:RET5.2编写程序,从键盘接收一个小写字母,然后找出它的前导字符和后续字符,再按顺序显示这三个字符。
答:程序段如下:BEGIN:MOV AH,1;从键盘输入一个字符的DOS调用INT21HCMP AL,‘a’;输入字符<‘a’吗?JB STOPCMP AL,‘z’;输入字符>‘z’吗?JA STOPDEC AL;得到前导字符MOV DL,AL;准备显示三个字符MOV CX,3DISPLAY:MOV AH,2;显示一个字符的DOS调用INT21HINC DLLOOP DISPLAYSTOP:RET5.3将AX寄存器中的16位数分成4组,每组4位,然后把这四组数分别放在AL、BL、CL 和DL中。
答:程序段如下:DSEG SEGMENTSTORE DB4DUP(?)DSEG ENDS┇BEGIN:MOV CL,4;右移四次MOV CH,4;循环四次LEA BX,STOREA10:MOV DX,AXAND DX,0FH;取AX的低四位MOV[BX],DL;低四位存入STORE中INC BXSHR AX,CL;右移四次DEC CHJNZ A10;循环四次完了码?B10:MOV DL,STORE;四组数分别放在AL、BL、CL和DL中MOV CL,STORE+1MOV BL,STORE+2MOV AL,STORE+3STOP:RET5.4试编写一程序,要求比较两个字符串STRING1和STRING2所含字符是否完全相同,若相同则显示‘MATCH’,若不相同则显示‘NO MATCH’。
答:程序如下:DSEG SEGMENTSTRING1DB‘I am a student.’STRING2DB‘I am a student!’YES DB‘MATCH’,0DH,0AH,‘$’NO DB‘NO MATCH’,0DH,0AH,‘$’DSEG ENDS;--------------------------------------------------------------------------CSEG SEGMENTMAIN PROC FARASSUME CS:CSEG,DS:DSEG,ES:DSEGSTART:PUSH DS;设置返回DOSSUB AX,AXPUSH AXMOV AX,DSEGMOV DS,AX;给DS赋值MOV ES,AX;给ES赋值;BEGIN:LEA SI,STRING1;设置串比较指令的初值LEA DI,STRING2CLDMOV CX,STRING2-STRING1REPE CMPSB;串比较JNE DISPNOLEA DX,YES;显示MATCHJMP DISPLAYDISPNO:LEA DX,NO;显示NO MATCHDISPLAY:MOV AH,9;显示一个字符串的DOS调用INT21HRETMAIN ENDPCSEG ENDS;以上定义代码段;--------------------------------------------------------------------------END START5.5试编写一程序,要求能从键盘接收一个个位数N,然后响铃N次(响铃的ASCII码为07)。
答:程序段如下:BEGIN:MOV AH,1;从键盘输入一个字符的DOS调用INT21HSUB AL,‘0’JB STOP;输入字符<‘0’吗?CMP AL,9;输入字符>‘9’吗?JA STOPCBWMOV CX,AX;响铃次数NJCXZ STOPBELL:MOV DL,07H;准备响铃MOV AH,2;显示一个字符的DOS调用,实际为响铃INT21HCALL DELAY100ms;延时100msLOOP BELLSTOP:RET5.6编写程序,将一个包含有20个数据的数组M分成两个数组:正数数组P和负数数组N,并分别把这两个数组中数据的个数显示出来。
答:程序如下:DSEG SEGMENTCOUNT EQU20ARRAY DW20DUP(?);存放数组COUNT1DB0;存放正数的个数ARRAY1DW20DUP(?);存放正数COUNT2DB0;存放负数的个数ARRAY2DW20DUP(?);存放负数ZHEN DB0DH,0AH,‘The positive number is:’,‘$’;正数的个数是:FU DB0DH,0AH,‘The negative number is:’,‘$’;负数的个数是:CRLF DB0DH,0AH,‘$’DSEG ENDS;--------------------------------------------------------------------------CSEG SEGMENTMAIN PROC FARASSUME CS:CSEG,DS:DSEGSTART:PUSH DS;设置返回DOSSUB AX,AXPUSH AXMOV AX,DSEGMOV DS,AX;给DS赋值BEGIN:MOV CX,COUNTLEA BX,ARRAYLEA SI,ARRAY1LEA DI,ARRAY2BEGIN1:MOV AX,[BX]CMP AX,0;是负数码?JS FUSHUMOV[SI],AX;是正数,存入正数数组INC COUNT1;正数个数+1ADD SI,2JMP SHORT NEXTFUSHU:MOV[DI],AX;是负数,存入负数数组INC COUNT2;负数个数+1ADD DI,2NEXT:ADD BX,2LOOP BEGIN1LEA DX,ZHEN;显示正数个数MOV AL,COUNT1CALL DISPLAY;调显示子程序LEA DX,FU;显示负数个数MOV AL,COUNT2CALL DISPLAY;调显示子程序RETMAIN ENDP;--------------------------------------------------------------------------DISPLAY PROC NEAR;显示子程序MOV AH,9;显示一个字符串的DOS调用INT21HAAM;将(AL)中的二进制数转换为二个非压缩BCD码ADD AH,‘0’;变为0~9的ASCII码MOV DL,AHMOV AH,2;显示一个字符的DOS调用INT21HADD AL,‘0’;变为0~9的ASCII码MOV DL,ALMOV AH,2;显示一个字符的DOS调用INT21HLEA DX,CRLF;显示回车换行MOV AH,9;显示一个字符串的DOS调用INT21HRETDISPLAY ENDP;显示子程序结束CSEG ENDS;以上定义代码段;--------------------------------------------------------------------------END START5.7试编写一个汇编语言程序,求出首地址为DATA的100D字数组中的最小偶数,并把它存放在AX中。
答:程序段如下:BEGIN:MOV BX,0MOV CX,100COMPARE:MOV AX,DATA[BX];取数组的第一个偶数ADD BX,2TEST AX,01H;是偶数吗?LOOPNZ COMPARE;不是,比较下一个数JNZ STOP;没有偶数,退出JCXZ STOP;最后一个数是偶数,即为最小偶数,退出COMPARE1:MOV DX,DATA[BX];取数组的下一个偶数ADD BX,2TEST DX,01H;是偶数吗?JNZ NEXT;不是,比较下一个数CMP AX,DX;(AX)<(DX)吗?JLE NEXTMOV AX,DX;(AX)<(DX),则置换(AX)为最小偶数NEXT:LOOP COMPARE1STOP:RET5.8把AX中存放的16位二进制数K看作是8个二进制的“四分之一字节”。
试编写程序要求数一下值为3(即11B)的四分之一字节数,并将该数(即11B的个数)在终端上显示出来。
答:程序段如下:BEGIN:MOV DL,0;计数初始值MOV CX,8COMPARE:TEST AX,03H;是数03吗?JNZ NOEQUAL;不是,转走INC DL;是,计数NOEQUAL:ROR AX,1;准备判断下一个数ROR AX,1LOOP COMPAREADD DL,‘0’;将计数值转换为ASCII码MOV AH,2;进行显示INT21HSTOP:RET5.9试编写一个汇编语言程序,要求从键盘接收一个四位的16进制数,并在终端上显示与它等值的二进制数。
答:程序段如下:BEGIN:MOV BX,0;用于存放四位的16进制数MOV CH,4MOV CL,4INPUT:SHL BX,CL;将前面输入的数左移4位MOV AH,1;从键盘取数INT21HCMP AL,30H;<0吗?JB INPUT;不是‘0~F’的数重新输入CMP AL,39H;是‘0~9’吗?JA AF;不是,转‘A~F’的处理AND AL,0FH;转换为:0000B~1001BJMP BINARYAF:AND AL,11011111B;转换为大写字母CMP AL,41H;又<A吗?JB INPUT;不是‘A~F’的数重新输入CMP AL,46H;>F吗?JA INPUT;不是‘A~F’的数重新输入AND AL,0FH;转换为:1010B~1111BADD AL,9BINARY:OR BL,AL;将键盘输入的数进行组合DEL CHJNZ INPUTDISPN:MOV CX,16;将16位二进制数一位位地转换成ASCII码显示DISP:MOV DL,0ROL BX,1RCL DL,1OR DL,30HMOV AH,2;进行显示INT21HLOOP DISPSTOP:RET5.10设有一段英文,其字符变量名为ENG,并以$字符结束。
试编写一程序,查对单词SUN 在该文中的出现次数,并以格式“SUN:xxxx”显示出次数。
答:程序如下:DSEG SEGMENTENG DB‘Here is sun,sun,…,$’DISP DB‘SUN:’DAT DB‘0000’,0DH,0AH,‘$’KEYWORD DB‘sun’DSEG ENDS;--------------------------------------------------------------------------CSEG SEGMENTMAIN PROC FARASSUME CS:CSEG,DS:DSEG,ES:DSEGSTART:PUSH DS;设置返回DOSSUB AX,AXPUSH AXMOV AX,DSEGMOV DS,AX;给DS赋值MOV ES,AX;给ES赋值BEGIN:MOV AX,0MOV DX,DISP-ENG-2;计算ENG的长度(每次比较sun,因此比较次数-2)LEA BX,ENGCOMP:MOV DI,BXLEA SI,KEYWORDMOV CX,3REPE CMPSB;串比较JNZ NOMATCHINC AX;是,SUN的个数加1ADD BX,2NOMATCH:INC BX;指向ENG的下一个字母DEC DXJNZ COMPDONE:MOV CH,4;将次数转换为16进制数的ASCII码MOV CL,4LEA BX,DAT;转换结果存入DAT单元中DONE1:ROL AX,CLMOV DX,AXAND DL,0FH;取一位16进制数ADD DL,30HCMP DL,39HJLE STOREADD DL,07H;是“A~F”所以要加7STORE:MOV[BX],DL;转换结果存入DAT单元中INC BXDEC CHJNZ DONE1DISPLAY:LEA DX,DISP;显示字符串程序(将DISP和DAT一起显示)MOV AH,09HINT21HRETMAIN ENDPCSEG ENDS;以上定义代码段;--------------------------------------------------------------------------END START5.11从键盘输入一系列以$为结束符的字符串,然后对其中的非数字字符计数,并显示出计数结果。