1、钱晓捷新版汇编语言程序设计习题答案修改钱晓捷新版汇编语言程序设计习题答案第一章 汇编语言基础知识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(
2、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)10111001 (2)10111001 (3)10111001 (4)101110001001 (5)1011 1011 (8)1011 10011001(6)
3、10111001(7)1.10数码09、大写字母AZ、小写字母az对应的ASCII码分别是多少?ASCII码为0dh、0ah对应的是什么字符?1.11、计算机中有一个“01100001”编码,如果把它认为是无符号数,它是10进制什么数?如果认为它是BCD码,则表示什么数?又如果它是某个ASCII码,则代表哪个字符?1.12、简述Intel 80x86系列微处理器在指令集方面的发展。1.13、什么是DOS和ROM-BIOS?1.14、简述PC机最低1MB主存空间的使用情况。1.15、罗列8086CPU的8个8位和16位通用寄存器,并说明各自的作用。1.16、什么是标志,它有什么用途?状态标志和控
4、制标志有什么区别?画出标志寄存器FLAGS,说明各个标志的位置和含义。1.17、举例说明CF和OF标志的差异。溢出标志OF和进位标志CF是两个意义不同的标志 进位标志表示无符号数运算结果是否超出范围,运算结果仍然正确;溢出标志表示有符号数运算结果是否超出范围,运算结果已经不正确例1:3AH+7CHB6H 无符号数运算:58124182,范围内,无进位 有符号数运算:58124182,范围外,有溢出例2:AAH+7CH(1)26H 无符号数运算:170124294,范围外,有进位 有符号数运算:8612428,范围内,无溢出1.18、字和双字在存储器中如何存放,什么是“小端方式”?对字和双字存储
5、单元,什么是它们的对齐地址?为什么要对齐地址?1.19、什么是8086中的逻辑地址和物理地址?逻辑地址如何转换成物理地址?请将如下逻辑地址用物理地址表达: (1)FFFFh:0(2)40h:17h(3)2000h:4500h(4)B821h:4567h1.20、8086有哪4种逻辑段,各种逻辑段分别是什么用途?(解答)代码段(CodeSegment)用来存放程序的指令序列。处理器利用CS:IP取得下一条要执行的指令 堆栈段(StackSegment)确定堆栈所在的主存区域。处理器利用SS:SP操作堆栈中的数据 数据段(DataSegment)存放当前运行程序所用的数据。处理器利用DS:EA存取
6、数据段中的数据 附加段(ExtraSegment)是附加的数据段,也用于数据的保存。处理器利用ES:EA存取数据段中的数据第二章8086指令系统2.1已知DS2000H、BX=0100H、SI=0002H,存储单元20100H20103H依次存放12345678H,21200H21203H依次存放2A4CB765H,说明下列每条指令执行完后AX寄存器的内容。 (1)movax,1200h ;AX1200h(2)movax,bx ; AX0100h(3)movax,1200h ; AX4C2Ah(4)movax,bx ; AX3412h(5)movax,bx+1100h ; AX4C2Ah(6)
7、movax,bx+si ; AX7856h(7)movax,bxsi+1100h ; AX65B7h2.2指出下列指令的错误 (1)movcx,dl 两操作数类型不匹配 (2)movip,ax IP 指令指针禁止用户访问 (3)moves,1234h 立即数不允许传给段寄存器 (4)moves,ds 段寄存器之间不允许传送 (5)moval,300 两操作数类型不匹配 (6)movsp,ax 目的操作数应为BP (7)movax,bx+di 源操作数应为BX+DI (8)mov20h,ah 立即数不能作目的操作数 2.3已知数字09对应的格雷码依次为:18H、34H、05H、06H、09H、0
8、AH、0CH、11H、12H、14H,它存在于以table为首地址(设为200H)的连续区域中。请为如下程序段的每条指令加上注释,说明每条指令的功能和执行结果。leabx,table;获取table的首地址,BX200H moval,8;传送欲转换的数字,AL8 xlat;转换为格雷码,AL12H 2.4什么是堆栈,它的工作原则是什么,它的基本操作有哪两个,对应哪两种指令?堆栈是一种按“先进后出”原则存取数据的存储区域。 堆栈的两种基本操作是压栈和出栈,对应的指令是PUSH和POP。 2.5已知SS=FFA0H、SP=00B0H,画图说明执行下面指令序列时,堆栈区和SP的内容如何变化? mov
9、ax,8057h pushax movax,0f79h pushax popbx ;bx=0f79h popbx ;DS:0f79h=8057h 2.6 给出下列各条指令执行后AL值,以及CF、ZF、SF、OF和PF的状态:moval,89h AL=89hCFZFSFOFPF addal,al AL=12h10011 addal,9dh AL=0afh00101 cmpal,0bch AL=0afh10101 subal,al AL=00h01001 decal AL=0ffh00101incal AL=00h01001 2.7设X、Y、Z均为双字数据,分别存放在地址为X、X+2;Y、Y+2;
10、Z、Z+2的存储单元中,它们的运算结果存入W单元。阅读如下程序段,给出运算公式。 movax,X movdx,X+2 addax,Y adcdx,Y+2 addax,24 adcdx,0 subax,Z sbbdx,Z+2 movW,ax movW+2,dxW=X+Y+24-Z 2.8请分别用一条汇编语言指令完成如下功能: (1)把BX寄存器和DX寄存器的内容相加,结果存入DX寄存器。 ADDDX,BX(2)用寄存器BX和SI的基址变址寻址方式把存储器的一个字节与AL寄存器的内容相加,并把结果送到AL中。 ADDAL,BX+SI(3)用BX和位移量0B2H的寄存器相对寻址方式把存储器中的一个字
11、和CX寄存器的内容相加,并把结果送回存储器中。 ADDBX+0B2H,CX(4)用位移量为0520H的直接寻址方式把存储器中的一个字与数3412H相加,并把结果送回该存储单元中。 ADDWORDPTR0520H,3412H(5)把数0A0H与AL寄存器的内容相加,并把结果送回AL中。ADDAL,0A0H2.9;设X、Y、Z、V均为16位带符号数,分别装在X、Y、Z、V存储单元中,阅读如下程序段,得出它的运算公式,并说明运算结果存于何处。为了避免与操作数地址混淆,将题中X,Y,Z,V字操作数改为A,B,C,D movax,X;ax=A imulY;dx,ax=A*B(将操作数看作符号数,以下同)
12、 movcx,ax movbx,dx;bx,ax-dx,ax=A*B movax,Z;ax=C cwd;dx,ax=C(扩展符号后为双字) addcx,ax adcbx,dx;bx,cx-bx,cx+dx,ax=A*B+C subcx,540 sbbbx,0;bx,cxDI,转到above执行 cmpdx,di jaabove;jnbeabove (2)若AXSI,转到greater执行 cmpax,si jggreater;jnlegreater (3)若CX=0,转到zero执行 cmpcx,0jcxzzero jzzero (4)若AXSI产生溢出,转到overflow执行; cmpax
13、,di jooverflow (5)若SIAX,转到less_eq执行; cmpsi,ax cmpax,si jleless_eq jgeless_eq (6)若DIDX,转到below_eq执行。 cmpdi,dx cmpdx,di jbebelow_eq jaebelow_eq 2.25有一个首地址为array的20个字的数组,说明下列程序段的功能。 movcx,20 movax,0 movsi,ax sum_loop:addax,arraysi addsi,2 loopsum_loop movtotal,ax;答:将首地址为array得20个字的数组求和,并将结果存入total单元中。
14、2.26按照下列要求,编写相应的程序段: (1) 起始地址为string的主存单元中存放有一个字符串(长度大于6),把该字符串中的第1个和第6个字符(字节量)传送给DX寄存器。movsi,0 movdl,stringsi;第1个字符送dl寄存器 movsi,5 movdh,stringsi;第6个字符送dh寄存器 (2) 从主存buffer开始的4个字节中保存了4个非压缩BCD码,现按低(高)地址对低(高)位的原则,将它们合并到DX中。xorsi,si;si清零 moval,buffersi;第一字节 incsi movah,buffersi;第二字节 movcl,4 shlah,cl;BCD
15、码移到高半字节 oral,ah;组合成压缩BCD码 movdl,al;存入dl寄. incsi moval,buffersi;第三字节 incsi movah,buffersi;第四字节 movcl,4 shlah,cl;BCD码移到高半字节 oral,ah;组合成压缩BCD码 movdh,al;存入dh寄. (3) 编写一个程序段,在DX高4位全为0时,使AX=0;否则使AX=-1。testdx,0f000h jzzero movax,-1 jmpdone zero:movax,0 done:ret (4) 有两个64位数值,按“小端方式”存放在两个缓冲区buffer1和buffer2中,编写程序段完成buffer1buffer2功能。leabx,buffer1 leadx,buffer2 movcx,8;8个字节 xorsi,si;si=0 clc;CF=0 (5) 假设从B800h:0开始存放有100个16位无符号数,编程求它们的和,并把32位的和保存在DX.AX中。movax,0b800h movds,ax;段地址 xorsi,si;地址偏移量si=0 xordx,dx;和的高字dx=0 movcx,99;加的次数 movax,si
copyright@ 2008-2022 冰豆网网站版权所有
经营许可证编号:鄂ICP备2022015515号-1