2022年2022年汇编语言程序设计基础习题 .pdf

上传人:C****o 文档编号:39689660 上传时间:2022-09-07 格式:PDF 页数:10 大小:127.94KB
返回 下载 相关 举报
2022年2022年汇编语言程序设计基础习题 .pdf_第1页
第1页 / 共10页
2022年2022年汇编语言程序设计基础习题 .pdf_第2页
第2页 / 共10页
点击查看更多>>
资源描述

《2022年2022年汇编语言程序设计基础习题 .pdf》由会员分享,可在线阅读,更多相关《2022年2022年汇编语言程序设计基础习题 .pdf(10页珍藏版)》请在得力文库 - 分享文档赚钱的网站上搜索。

1、1 第 5 章 汇编语言程序设计1.下列标号为什么是非法的?(1)GET.DATA(2)1_NUM(3)TEST-DATA(4)RET(5)NEW ITEM 答案:(1)因为.只允许是标号的第一个字符(2)第一个字符不能为数字(3)不允许出现-(4)不能是保留字,如助记符(5)不能有空格2.下面的数据项定义了多少个字节?DATA_1 DB 6 DUP(4 DUP(0FFH,89H)答案:48 字节3.下面两个数据段中偏移地址为10H 和 11H 的两个存储单元中的数据是一样的吗?为什么?DTSEG SEGMENT ORG 10H DATA1 DB 72H DB 04H DTSEG ENDS D

2、TSEG SEGMENT ORG 10H DATA1 DW 7204H DTSEG ENDS 答案:不一样。分别是 72H,04H 和 04H,72H。存储字时低8 位存在低字节,高 8 位存在高字节。4.下面的数据项设置了多少个字节?(1)ASC_DA TA DB 1234(2)HEX_DATA DB 12 H,34H 答案:(1)设置了 4 个字节(2)设置了 2 个字节5判断以下说法是否正确,如有错,请说明原因并改正。(1)伪指令在汇编过程中不会产生二进制代码。(2)宏和过程的相同之处是都可用于简化源程序书写、精简目标代码。(3)在计算机中,高级语言通常需要转换为汇编语言后才能执行。(4

3、)汇编语言程序上机一般包括编辑、汇编、链接和调试几个步骤。答:(1)正确。(2)错误。宏不能精简目标代码。(3)错误。高级语言程序经编译或解释后直接转换为目标代码。(4)正确。6已知数据和符号定义A1 DB?A2 DB 8 K1 EQU 100 判断下列指令的正误,并说明错误指令的原因。(1)MOV K1,AX(2)MOV A2,AH(3)CMP A1,A2(4)MOV BX,K1 MOV BX,DX(5)K1 EQU 200 名师资料总结-精品资料欢迎下载-名师精心整理-第 1 页,共 10 页 -2 答:(1)错。K1 是符号常数,在此处相当于立即数100,故不能做目的操作数。(2)正确。

4、(3)错。A1、A2 都是字节变量,相当于两个存储器单元,故不能同时出现在一条指令中直接进行比较。(4)正确。(5)错。用EQU 定义的符号不能重新赋值,除非已用PURGE 解除了原值。7若数据段中有定义NUM1 EQU 23H NUM2 DW 0 则指令MOV NUM2,NUM1 的源、目操作数的寻址方式以及指令执行后NUM2 1单元的内容分别是什么?答:指令MOV NUM2,NUM1 的源操作数使用立即数寻址,目的操作数使用直接寻址。指令执行后NUM2 1 单元的内容是0。8已知某数据段从物理地址03000H 处开始,定义如下:DSEG SEGMENT ORG 2000H A1 DD 2

5、DUP(7,1,?)A2 DB 10 DUP(0,4,3 DUP(2),5)CNT EQU 20H A3 DW 100 DUP(?)DSEG ENDS 请分别用分析运算符SEG、OFFSET、LENGTH、SIZE、TYPE 求出 A1、A2、A3 的段基址、偏移量、类型及它们的LENGTH、SIZE。答:(SEG A1)=0300H,(OFFSET A1)=2000H,(TYPE A1)=4,(LENGTH A1)=2,(SIZE A1)=24=8;(SEG A2)=0300H,(OFFSET A2)=2018H,(TYPE A2)=1,(LENGTH A2)=10,(SIZE A2)=10

6、 1=60;(SEG A3)=0300H,(OFFSET A3)=2054H,(TYPE A3)=2,(LENGTH A3)=100,(SIZE A3)=100 2=200 9已知符号定义语句如下:ALPHA EQU 100 BETA EQU 25 GAMMA EQU 2 分别求下列各表达式的值。(1)ALPHA*4 GT BETA(2)ALPHA MOD GAMMA BETA(3)(BETA/3)LE 5(4)ALPHA AND BETA(5)GAMMA XOR(BETA EQ 25)答案:(1)ALPHA*4 GT BETA=100*4 GT 25=0FFFFH(2)ALPHA MOD G

7、AMMA BETA=100 MOD 2 25=25(3)(BETA/3)LE 5=(25/3)LE 5=0 名师资料总结-精品资料欢迎下载-名师精心整理-第 2 页,共 10 页 -3(4)ALPHA AND BETA=100 AND 25=64H&19H=0(5)GAMMA XOR(BETA EQ 25)=2(25 EQ 25)=0FFFDH 10根据下列要求编写一个汇编语言程序:1)代码段的段名为COD_SG 2)数据段的段名为DAT_SG 3)堆栈段的段名为STK_SG 4)变量 D1 所包含的数据为95 5)将变量D1 装入 AH,BH 和 DL 6)程序运行的入口地址为START 答

8、案:DAT_SG SEGEMNT D1 DB 95 DAT_SG ENDS STK_SG SEGMENT DW 64 DUP(?)STK_SG ENDS COD_SG SEGMENT MAIN PROC FAR ASSUME CS:COD_SG ASSUME DS:DAT_SG,SS:STK_SG START:MOV AX,DA T-SG MOV DS,AX MOV AH,D1 MOV BH,AH MOV DL,AH MOV AH,4CH INT 21H MAIN ENDP COD_SG ENDS END START 11.执行下列指令后,AX 寄存器中的内容是什么?TABLE DW 10,2

9、0,30,40,50 ENTRY DW 3.MOV BX,OFFSET TABLE ADD BX,ENTRY MOV AX,BX 答案:(AX)=1E00H12.指出下列程序中的错误:STAKSG SEGMENT DB 100 DUP(?)STA_SG ENDS DTSEG SEGMENT DATA1 DB?DTSEG END CDSEG SEGMENT MAIN PROC FAR START:MOV DS,DATSEG MOV AL,34H ADD AL,4FH MOV DATA,AL START ENDP CDSEG ENDS END 答案:改正后:STAKSG SEGMENT DB 10

10、0 DUP(?)名师资料总结-精品资料欢迎下载-名师精心整理-第 3 页,共 10 页 -4 STAKSG ENDS(段名必须一致)DTSEG SEGMENT DATA1 DB?DTSEG ENDS(段的结束符为ENDS)CDSEG SEGMENT MAIN PROC FAR ASSUME CS:CDSEG,DS:DTSEG,SS:STAKSG(必须把涉及的段的段名与相应的段寄存器联系起来)START:MOV AX,DTSEG MOV DS,AX(不能利用立即数寻址方式向段寄存器赋初值)MOV AL,34H ADD AL,4FH MOV DATA1,AL MOV AH,4CH INT 21H(

11、程序执行完后必须返回DOS)MAIN ENDP(过程名前后必须一致)CDSEG ENDS END START(对主程序来说,程序结束符后必须跟程序的开始符)13.DATA SEGMENT TABLE_ADDR DW 1234H DATA ENDS.MOV BX,TABLE_ADDR LEA BX,TABLE_ADDR 请写出上述两条指令执行后,BX 寄存器中的内容。答案:MOV BX,TABLE_ADDR;执行后(BX)=1234H LEA BX,TABLE_ADDR;执行后(BX)=OFFSET TABLE_ADDR 14试编写一个汇编语言程序段,要求对键盘输入的小写字母用大写字母显示出来。

12、答案:abc:mov ah,1 int 21h cmp al,ajb stop cmp al,zja stop sub al,20h mov dl,al mov ah,2 int 21h jmp abc stop:ret 15编写程序,比较两个字符串STRING1和 STRING2所含字符是否完全相同,若相同则显示“MATCH”,若不同则显示“NO MATCH”。名师资料总结-精品资料欢迎下载-名师精心整理-第 4 页,共 10 页 -5 答案:datarea segment string1 db asfioastring2 db xcviyoaf mess1 db MATCH,$mess2

13、db NO MA TCH,$datarea ends prognam segment main proc far assume cs:prognam,ds:datarea start:push ds sub ax,ax push ax;返回 DOS mov ax,datarea mov ds,ax mov es,ax;赋初值begin:mov cx,string2-string1 mov bx,mess1-string2 cmp bx,cx;比较两字符串的长度jnz dispno lea si,string1;若长度相同lea di,string2;地址指针赋初值repe cmpsb;比较jn

14、e dispno mov ah,9;相同,显示MATCH lea dx,mess1 int 21h ret dispno:mov ah,9;不同,显示 NO MA TCH lea dx,mess2 int 21h ret main endp prognam ends end start 16把 010010之间的 30 个数,存入首地址为GRAD 的字数组中,GRADE+i表示学号为i+1的学生成绩。另一个数组RANK 是 30 个学生的名次表,其中RANK+I的内容是学号为i+1 的学生的名次。试编写程序,根据GRAD 中的学生成绩,将排列的名次填入RANK 数组中(提示:一个学生的名次等于

15、成绩高于这个学生的人数加1)。答案:dseg segment grade dw 30 dup(?)rank dw 30 dup(?)dseg ends cseg segment main proc far assume cs:cseg,ds:dseg,es:dseg start:push ds sub ax,ax push ax mov ax,dseg mov ds,ax mov es,ax begin:mov di,0 mov cx,30 loop1:push cx mov cx,30 mov si,0 mov ax,gradedi mov dx,0 loop2:cmp gradesi,ax

16、 jbe go_on inc dx go_on:add si,2 loop loop2 pop cx inc dx mov rankdi,dx add di,2 loop loop1 ret mainendp cseg ends end start 名师资料总结-精品资料欢迎下载-名师精心整理-第 5 页,共 10 页 -6 17编写一个程序,接收从键盘输入的10 个十进制数字,输入回车符则停止输入,然后将这些数字加密后(用XLAT 指令变换)存入内存缓冲区BUFFER。加密表为:输入数字:0,1,2,3,4,5,6,7,8,9 密码数字:7,5,9,1,3,6,8,0,2,4 答案:scod

17、e db 7,5,9,1,3,6,8,0,2,4 buffer db 10 dup(?);mov si,0 mov cx,10 lea bx,scode input:mov ah,01 int 21h cmp al,0ah jz exit and al,0fh xlat mov buffersi,al inc si loop input exit:ret 18读下面程序,在其中的空处添上适当内容。该程序完成了什么功能?程序运行后,变量 RS 的值是多少?DATA SEGMENT BUF DB-13,24,5,-62 DB 77,20,-7,145,0 CNT DB$-BUF RS DB 0 D

18、ATA ENDS STACK SEGMENT PARA STACK DB 256 DUP(?)STACK ENDS CODE SEGMENT ASSUME CS:CODE,DS:DATA ASSUME SS:STACK START PROC FAR PUSH DS MOV AX,0 PUSH AX MOV AX,DATA MOV DS,AX LEA BX,BUF MOV CH,0 MOV CL,LP:MOV AL,BX TEST AL,80H JE CONT INC RS CONT:INC BX LOOP LP RET START ENDP CODE ENDS END START 答:程序空处

19、可填CNT,字节变量RS 的最后结果是04H。该程序实现的功能是:统计数据段中以BUF为首址的带符号字节数据表中负数的个数,CNT为表中所有数据的个数,即表的长度。需要注意的是:十进制数据“145”在以二进制带符号字节数据形式存放时相当于“111”。19编写一个完整的源程序,将数据35、-27、-1 3、6、-47、52、9、-3 中的正数放入以BUFFER为首址的数据缓冲区中。答:一种可能的程序如下实现:名师资料总结-精品资料欢迎下载-名师精心整理-第 6 页,共 10 页 -7 DATA SEGMENT BLOCK DB 35,27,13,6,47,52,9,3 COUNT EQU$BLO

20、CK BUFFER DB COUNT DUP(?)DATA ENDS STACK SEGMENT PARA STACKSTACK DW 40 DUP(?)STACK ENDS CODE SEGMENT ASSUME CS:CODE,DS:DATA,ES:DATA,SS:STACK BEGIN:MOV AX,DATA MOV DS,AX MOV ES,AX;需用STOS 串操作指令MOV CX,COUNT LEA SI,BLOCK;源数据区指针LEA DI,BUFFER;正数存放区指针CLD ;自动增量 AGAIN:LODSB;取源数据,并修改SI TEST AL,80H;取符号位,不影响AL

21、JS GO;符号位=1,是负数,不存STOSB;存正数并修改DI GO:LOOP AGAIN MOV AH,4CH ;退出循环,返回DOS INT 21H CODE ENDS END BEGIN 20从内存单元BUF 开始的缓冲区中有7 个 8 位无符号数,依次为13H、0D8H、92H、2AH、66H、0E0H、3FH。编程找出它们的中间值并放入RES 单元,且将结果以“(RES)=?”的格式显示在屏幕上。答:一种可能的程序如下实现:DATA SEGMENT BUF DB 13H,0D8H,92H,2AH,66H,0E0H,3FH RES DB?;中间数的存放单元 STR DB(RES)=S

22、TR1 DB?,?,$;结果字符串DATA ENDS SSEG SEGMENT PARA STACKSSEGDB 100 DUP(?)SSEG ENDS CODE SEGMENT ASSUME CS:CODE,SS:SSEG,DS:DATA,ES:DATA MAIN PROC FAR;主程序PUSH DS XOR AX,AX PUSH AX MOV AX,DATA MOV DS,AX MOV ES,AX;有 STOS 指令,需用ES MOV CX,6;外循环次数,比6 次 AGN:MOV SI,OFFSET BUF MOV DI,SI INC DI;SI、DI 指向相邻2 数MOV DX,6;

23、内循环次数,比6 次 AGN1:MOV AL,SI 名师资料总结-精品资料欢迎下载-名师精心整理-第 7 页,共 10 页 -8 CMP AL,DI;两个无符号数相比较JB UNCH;小于则转,不互换 EXCH:XCHG AL,DI ;前 1 单元较大,则互换MOV SI ,AL;大数放在后面 UNCH:INC SI;修改指针,指向下一个数INC DI DEC DX JNZ AGN1;未处理完,继续内循环LOOP AGN;外循环 DONE:MOV AL,SI 3;排序完成,取中间数MOV RES,AL AND AL,0F0H;分离高半字节MOV CL,4 SHR AL,CL CALL BATR

24、;调子程序,将AL 值转换为ASCII 码LEA DI,STR1;DI 指向结果单元CLD STOSB;存放转换结果MOV AL,RES AND AL,0FH ;分离并转换低半字节CALL BATR STOSB LEA DX,STR ;显示整个字符串MOV AH,09H INT 21H RET MAIN ENDP;主程序MAIN结束;子程序BATR,实现 16 进制数到ASCII 码的转换 BATR PROC NEAR CMP AL,10;入口参数为AL JB NUM;是数字,则转NUM ADD AL,A 10 0;字母 NUM:ADD AL,0RET BATR ENDP;子程序结束 CODE

25、 ENDS END MAIN 简析:本例的基本思路是:先把7 个无符号数按大小排序,排序完成之后取位于中间的一个数即为中间值。然后将该16 进制数转换为两个对应的ASCII 码,再与要求的格式字符一起输出送显即可。数据排序可以是从大到小、或从小到大排列,本参考程序完成从小到大排序,由一个双重循环结构实现。内循环完成一个数与其它数之间的一一比较,并使每次比较所得的小数置于低地址单元。外循环实现所有数之间的两两相较。共7 个数据,故内、外循环中的比较次数均为6 次。编程时需注意:无符号数比较大小应使用JA、JB、JAE、JBE 指令,本例完成从小到大的排列,故用JB 控制转移到UNCH;若要从大到

26、小排列,则用JA 代替 JB 即可。对两个循环体进行初始化时,需仔细考虑指针和循环控制寄存器的初值。在数据段的定义中,分别定义STR、STR1 两个变量名字,是为了便于在STR1 处存放转换结果;显示时使 DX 直接指向STR,以 STR1 末尾的“$”为结束符。中间值找出之后,应把高、低半名师资料总结-精品资料欢迎下载-名师精心整理-第 8 页,共 10 页 -9 字节相分离,并分别转换为各所对应的ASCII 码。21设某测试系统中,1 号端口为测试口,所得数据是09 之间的十进制整数;2 号端口为显示口,对应于数字09 的 LED 七段共阴显示码依次为:3FH、06H、5BH、4FH、66

27、H、6DH、3DH、07H、7FH、6FH。编写一段查表送显的程序,要求:先从测试口读入一个数据,再查表将相应的显示码从显示口送出,如此反复进行直至读入数据“0FFH”为止。答:一种可能的程序如下实现:DATA SEGMENT TAB DB 3FH,06H,5BH,4FH,66H DB 6DH,3DH,07H,7FH,6FH ;09 的七段码DATA ENDS STACK SEGMENT PARA STACKSTACK DW 50 DUP(?)STACK ENDS CODE SEGMENT ASSUME CS:CODE,SS:STACK,DS:DATA START:MOV AX,DATA MO

28、V DS,AX LE BX,TAB ;BX 指向表首址 NEXT:IN AL,1;从测试口输入CMP AL,0FFH JE STOP;是 0FFH,结束XLAT TAB ;不是0FFH,查表转换OUT 2,AL;向显示口输出七段码JMP NEXT;继续测试 STOP:MOV AH,4CH INT 21H CODE ENDS END START 22有一个长度不超过100 字节的字符串,以回车符结尾。编程统计其中非空格的字符个数,并将统计结果以自拟格式显示在CRT 上。答:一种可能的程序如下实现:DATA SEGMENT STR DB It s a fine day,isn t it?,0DH,

29、$;依题意以0DH 为结束符。加上“$”便于显示整个字符串 COUNT EQU$STR2;串长中不包括结束符和“$”符号 NUM DB 0;置统计结果初值为0 STR1 DB The number of non-space charactors is,$DATA ENDS STACK SEGMENT PARA STACKSTACK DB 100 DUP(?)STACK ENDS CODE SEGMENT ASSUME CS:CODE,SS:STACK,DS:DATA,ES:DATA START:MOV AX,DATA MOV DS,AX MOV ES,AX;有 SCAS 指令,需用ES LEA

30、 DI,STR CLD MOV AL,20H;关键字符(空格)MOV CX,COUNT NEXT:SCASB JE SKIP;是空格,跳过下一句名师资料总结-精品资料欢迎下载-名师精心整理-第 9 页,共 10 页 -10 INC NUM;非空格字符,NUM 加 1 SKIP:LOOP NEXT LEA DX,STR ;显示原字符串MOV AH,09H INT 21H MOV DL,0AH ;显示换行符,以便显示另一字串MOV AH,2 INT 21H LEA DX,STR1;显示另一个字符串MOV AH,9 INT 21H;将 16 进制的统计结果转换为十进制数,再转换为两个ASCII 码输

31、出MOV AL,NUM MOV AH,0;AX 中为待转换16 进制数MOV BL,10 DIV BL;AX/BL;商(十位)在AL 中,余数(个位)在AH 中,均为未组合BCD 码PUSH AX;入栈保护OR AL,30H;将十位数转换为ASCII 码MOV DL,AL;送 CRT 显示MOV AH,2 INT 21H POP AX;恢复除法运算的结果ADD AH,30H;将个位数转换为ASCII 码MOV DL,AH;显示MOV AH,2 INT 21H MOV AH,4CH ;完成,返回DOS INT 21H CODE ENDS END START 简析:本例的关键在于统计结果的显示。统

32、计完成后,结果单元中是一个16 进制数。为符合一般习惯,应在CRT 上显示十进制数,因此首先用除法将十位、个位分离开,再将其分别转换为ASCII 码输出。由于除数是10,故相除之后得到的商(十位数)和余数(个位数)必在09 范围内,即未组合BCD 码,所以很容易转换为ASCII 码。编程时注意:DIV 指令执行后结果在AX 中,而DOS 功能调用必须用AH 为调用号,故应保护AX 的内容。另外,原题已告知字串的结束符是0DH,故亦可通过检索结束符(0DH)的方式控制循环。另外请注意:数据段中定义的STR 串中出现的单引号前必须用另一个单引号转义,如“s”应为“s”。名师资料总结-精品资料欢迎下载-名师精心整理-第 10 页,共 10 页 -

展开阅读全文
相关资源
相关搜索

当前位置:首页 > 教育专区 > 高考资料

本站为文档C TO C交易模式,本站只提供存储空间、用户上传的文档直接被用户下载,本站只是中间服务平台,本站所有文档下载所得的收益归上传人(含作者)所有。本站仅对用户上传内容的表现方式做保护处理,对上载内容本身不做任何修改或编辑。若文档所含内容侵犯了您的版权或隐私,请立即通知得利文库网,我们立即给予删除!客服QQ:136780468 微信:18945177775 电话:18904686070

工信部备案号:黑ICP备15003705号-8 |  经营许可证:黑B2-20190332号 |   黑公网安备:91230400333293403D

© 2020-2023 www.deliwenku.com 得利文库. All Rights Reserved 黑龙江转换宝科技有限公司 

黑龙江省互联网违法和不良信息举报
举报电话:0468-3380021 邮箱:hgswwxb@163.com