欢迎来到冰点文库! | 帮助中心 分享价值,成长自我!
冰点文库
全部分类
  • 临时分类>
  • IT计算机>
  • 经管营销>
  • 医药卫生>
  • 自然科学>
  • 农林牧渔>
  • 人文社科>
  • 工程科技>
  • PPT模板>
  • 求职职场>
  • 解决方案>
  • 总结汇报>
  • ImageVerifierCode 换一换
    首页 冰点文库 > 资源分类 > DOCX文档下载
    分享到微信 分享到微博 分享到QQ空间

    汇编语言课后习题解答.docx

    • 资源ID:2935703       资源大小:226.67KB        全文页数:34页
    • 资源格式: DOCX        下载积分:3金币
    快捷下载 游客一键下载
    账号登录下载
    微信登录下载
    三方登录下载: 微信开放平台登录 QQ登录
    二维码
    微信扫一扫登录
    下载资源需要3金币
    邮箱/手机:
    温馨提示:
    快捷下载时,用户名和密码都是您填写的邮箱或者手机号,方便查询和重复下载(系统自动生成)。
    如填写123,账号就是123,密码也是123。
    支付方式: 支付宝    微信支付   
    验证码:   换一换

    加入VIP,免费下载
     
    账号:
    密码:
    验证码:   换一换
      忘记密码?
        
    友情提示
    2、PDF文件下载后,可能会被浏览器默认打开,此种情况可以点击浏览器菜单,保存网页到桌面,就可以正常下载了。
    3、本站不支持迅雷下载,请使用电脑自带的IE浏览器,或者360浏览器、谷歌浏览器下载即可。
    4、本站资源下载后的文档和图纸-无水印,预览文档经过压缩,下载后原文更清晰。
    5、试题试卷类文档,如果标题没有明确说明有答案则都视为没有答案,请知晓。

    汇编语言课后习题解答.docx

    1、汇编语言课后习题解答第1章 基础知识检测点(第9页)(1)1个CPU的寻址能力为8KB,那么它的地址总线的宽度为13位。(2)1KB的存储器有1024个存储单元,存储单元的编号从0到1023。(3)1KB的存储器可以存储8192(213)个bit,1024个Byte。(4)1GB是24(230)个Byte、1MB是1048576(220)个Byte、1KB是1024(210)个Byte。(5)8080、8088、80296、80386的地址总线宽度分别为16根、20根、24根、32根,则它们的寻址能力分别为: 64(KB)、1(MB)、16(MB)、4(GB)。(6)8080、8088、808

    2、6、80286、80386的数据总线宽度分别为8根、8根、16根、16根、32根。则它们一次可以传送的数据为: 1(B)、1(B)、2(B)、2(B)、4(B)。(7)从内存中读取1024字节的数据,8086至少要读512次,80386至少要读256次。(8)在存储器中,数据和程序以 二进制形式存放。解题过程:(1)1KB=1024B,8KB=1024B*8=2N,N=13。(2)存储器的容量是以字节为最小单位来计算的,1KB=1024B。(3)8Bit=1Byte,1024Byte=1KB(1KB=1024B=1024B*8Bit)。(4)1GB=24B(即230)1MB=1048576B(

    3、即220)1KB=1024B(即210)。(5)一个CPU有N根地址线,则可以说这个CPU的地址总线的宽度为N。这样的CPU最多可以寻找2的N次方个内存单元。(一个内存单元=1Byte)。(6)8根数据总线一次可以传送8位二进制数据(即一个字节)。(7)8086的数据总线宽度为16根(即一次传送的数据为2B)1024B/2B=512,同理1024B/4B=256。(8)在存储器中指令和数据没有任何区别,都是二进制信息。第2章 寄存器检测点(第19页)(1)写出每条汇编指令执行后相关寄存器中的值。第一空:F4A3H第二空:31A3H第三空:3123H第四空:6246H第五空:826CH第六空:6

    4、246H第七空:826CH第八空:04D8H第九空:0482H第十空:6C82H第十一空:D882H第十二空:D888H第十三空:D810H第十四空:6246H(2)只能使用目前学过的汇编指令,最多使用4条指令,编程计算2的4次方。解答如下:mov ax,2add ax,axadd ax,axadd ax,ax检测点(第25页)(1)00010H,1000FH(2)1001H,2000H第2题说明:因为段的起始地址要为16的倍数。所以当段地址小于1001H或大于2000H时CPU都无法寻到。(1)解题过程:物理地址SA*16+EA EA的变化范围为0hffffh 物理地址范围为(SA*16+0

    5、h)(SA*16+ffffh) 现在SA=0001h,那么寻址范围为 (0001h*16+0h)(0001h*16+ffffh) =0010h1000fh (2)解题过程:物理地址SA*16+EA 20000hSA*16+EA SA=(20000h-EA)/16=2000h-EA/16 EA取最大值时,SA=2000h-ffffh/16=1001h,SA为最小值 EA取最小值时,SA=2000h-0h/16=2000h,SA为最大值 这里的ffffH/16=fffh是通过WIN自带计算器算的 按位移来算确实应该为,这里小数点后的f应该是省略了 单就除法来说,应有商和余数,但此题要求的是地址最大

    6、和最小,所以余数忽略了 如果根据位移的算法(段地址*1616进制左移一位),小数点后应该是不能省略的 我们可以反过来再思考下,如果SA为1000h的话,小数点后省略 SA=1000h,EA取最大ffffh,物理地址为1ffffh,将无法寻到20000H单元 这道题不应看成是单纯的计算题检测点(第35页)答:CPU修改了4次IP的值。情况如下:第1次:执行完mov ax,bx后第2次:执行完sub ax,ax后 ;该步执行后,寄存器ax清零第3次:读入jmp ax后第4次:执行完jmp ax后 ;连续两步ip均为0最后IP的值为0 ;最后IP的值为0000H,因为最后ax中的值为0000H,所以

    7、IP中的值也为0000H 第3章 寄存器(内存访问)检测点(第55页)(1)(题目:略)第一空:2662H第二空:E626H第三空:E626H第四空:2662H第五空:D6E6H第六空:FD48H第七空:2C14H第八空:0000H第九空:00E6H第十空:0000H第十一空:0026H第十二空:000CH提示:此题可在DEBUG中利用E命令在本机上按照题目中所给出的内存单元及其数据进行相应地修改,然后再用A命令进行写入(题目中所给出的)相应的汇编指令,最后再进行T命令进行逐步执行,以查看相应结果。(2)指令序列如下:mov ax,6622hjmp 0ff0:0100mov ax,2000hm

    8、ov ds,axmov ax,0008mov ax,00022.写出CPU执行每条指令后,CS、IP和相关寄存器中的数值。指令序列寄存器CSIPDSAXBX初始值2000H00001000H00mov ax,6622h2000H00031000H6622H0000jmp 0ff0:01001000H00001000H6622H0000mov ax,2000h1000H00031000H2000H0000mov ds,ax1000H00052000H2000H0000mov ax,00081000H00082000HC389H0000mov ax,00021000H000B2000HEA66H0

    9、000 3.再次体会:数据和程序有区别吗?如何确定内存中的信息哪些是数据,哪些是程序?检测点(第70页)(1)补全下面的程序,使其可以将10000H-1000FH中的8个字,逆序拷贝到20000H-2000FH中。mov ax,1000H mov ds,ax mov ax,2000H mov ss,ax mov sp,10h (2)补全下面的程序,使其可以将10000H-1000FH中的8个字,逆序拷贝到20000H-2000FH中。 mov ax,2000H mov ds, ax mov ax,1000Hmov ss, ax mov sp,0 检测点(第129页)(1)下面的程序实现依次用内

    10、存0:00:15单元中的内容改写程序中的数据,完成程序:assume cs:codesgcodesg segment dw 0123h,0456h,0789h,0abch,0defh,0fedh,0cbah,0987hstart: mov ax,0 mov ds, ax mov bx,0 mov cx,8 s: mov ax,bx mov cs:bx,ax add bx,2 loop s mov ax,4c00h int 21hcodesg endsend start(2)下面的程序实现依次用内存0:00:15单元中的内容改写程序中的数据,数据的传送用栈来进行。栈空间设置在程序内。完成程序:a

    11、ssume cs:codesgcodesg segment dw 0123h,0456h,0789h,0abch,0defh,0fedh,0cbah,0987h dw 0,0,0,0,0,0,0,0,0,0 ;10个字单元用作栈空间,所以栈空间的大小为10*2=20,化成16进制即为14start: mov ax, codesg;或mov ax, cs mov ss ,ax mov sp, 24h ;或mov sp, 36 ;10h+14h=24h mov ax,0 mov ds, ax mov bx,0 mov cx,8 s: push bx pop cs:bx ;或 pop ss:bx ;

    12、关键在于cs与ss此时地址相同 add bx,2 loop s mov ax,4c00h int 21hcodesg endsend start检测点(第183页)(1)程序如下:assume cs:codedata segment dw 2 dup (0)data endscode segment start: mov ax, data mov ds, ax mov bx,0 jmp word ptr bx+1code endsend start若要使jmp指令执行后,CS:IP指向程序的第一条指令,在data段中应该定义哪些数据? 答案db 3 dup (0)答案dw 2 dup (0)答

    13、案dd 0jmp word ptr bx+1为段内转移,要CS:IP指向程序的第一条指令,应设置ds:bx+1的字单元(2个字节)存放数据应为0,则(ip)=ds:bx+1=0简单来说就是,只要ds:bx+1起始地址的两个字节为0就可以了 (2)程序如下:assume cs:codedata segment dd hdata endscode segment start: mov ax,data mov ds,ax mov bx,0 mov bx, bx ;或mov bx, word ptr 0 ;或mov bx, offset start mov bx+2, cs ;或mov bx+2, c

    14、s ;或mov bx+2, seg code jmp dword ptr ds:0code endsend start补全程序,使用jmp指令执行后,CS:IP指向程序的第一条指令。 第一格可填mov bx,bx mov bx,word ptr 0 mov bx,offset start等。第二格可填mov bx+2,cs mov bx+2,cs mov bx+2,seg code等。解析:jmp dword ptr ds:0为段间转移,(cs)=(内存单元地址+2),(ip)=(内存单元地址),要CS:IP指向程序的第一条指令,第一条程序地址cs:0,应设置CS:IP指向cs:0程序中的mo

    15、v bx,bx这条指令,是将ip设置为0 mov bx+2,cs,将cs这个段地址放入内存单元 执行后,cs应该不变,只调整ip为0,(ip)=ds:0=0(3)用Debug查看内存,结果如下:2000:1000 BE 00 06 00 00 00 .则此时,CPU执行指令:mov ax,2000hmov es,axjmp dword ptr es:1000h后,(cs)= 0006H,(ip)= 00BEH 解析:jmp dword ptr为段间转移,高位存放段地址,低位存放偏移地址(cs)=(内存单元地址+2),(ip)=(内存单元地址) 根据书P16,对于寄存器AX,AH为高位(前1字节

    16、为高位),AL为低位(后1字节为低位)推算出(内存单元地址)=00BEH,(内存单元地址+2)=0006H根据书P182,高位存放段地址(后2个字节为高位),低位存放偏移地址(前2个字节为低位)(cs)=(内存单元地址+2),(ip)=(内存单元地址)推算出(cs)=0006H,(ip)=00BEH.检测点(第184页)补全编程,利用jcxz指令,实现在内存2000H段中查找第一个值为0的字节,找到后,将它的偏移地址存储在dx中。assume cs:codecode segment start: mov ax,2000h mov ds, ax mov bx,0 s: mov ch,0 mov

    17、cl,bx jcxz ok ;当cx=0时,CS:IP指向OK inc bx jmp short s ok: mov dx, bx mov ax ,4c00h int 21hcode endsend start检测点(第185页)补全编程,利用loop指令,实现在内存2000H段中查找第一个值为0的字节,找到后,将它的偏移地址存储在dx中。assume cs:codecode segmentstart: mov ax,2000h mov ds, ax mov bx,0 s:mov cl,bx mov ch,0 inc cx ;只要保证cx0,才能执行loop循环,切记! inc bx loop

    18、 s ok: dec bx mov dx, bx mov ax,4c00h int 21hcode endsend start检测点(第191页)补全程序,实现从内存1000:0000处开始执行指令。assume cs:codestack segment db 16 dup (0)stack endscode segmentstart: mov ax, stack mov ss, ax mov sp,16 mov ax, 1000h push ax mov ax, 0 push ax retfcode endsend start 执行reft指令时,相当于进行:pop ippop cs根据栈先

    19、进后出原则,应先将段地址cs入栈,再将偏移地址ip入栈。检测点(第192页)下面的程序执行后,ax中的数值为多少?内存地址 机器码 汇编指令 执行后情况1000:0 b8 00 00 mov ax,0 ax=0 ip指向1000:31000:3 e8 01 00 call s pop ip ip指向1000:71000:6 40 inc ax1000:7 58 s:pop ax ax=6 用debug进行跟踪确认,“call标号”是将该指令后的第一个字节偏移地址入栈,再转到标号处执行指令。检测点(第192页)下面的程序执行后,ax中的数值为多少? 内存地址 机器码 汇编指令 执行后情况 100

    20、0:0 b8 00 00 mov ax,0 ax=0, ip指向1000:31000:3 9a 09 00 00 10 call far ptr s pop cs,pop ip,ip指向1000:91000:8 40 inc ax1000:9 58 s: pop ax ax=8h add ax,ax ax=10h pop bx bx=1000h add ax,bx ax=1010h检测点(第194页)下面的程序执行后,ax中的数值为多少?内存地址 机器码 汇编指令 执行后情况1000:0 b8 06 00 mov ax,6 ax=6, ip指向1000:31000:3 ff d0 call a

    21、x pop ip, ip指向1000:61000:5 40 inc ax1000:6 58 mov bp ,sp bp=sp=fffeh ;栈顶的地址减去2,存放着05h add ax,bp ax=6+ds:(fffeh)=6+5=0bh 用debug进行跟踪确认,“call ax(16位reg)”是先将该指令后的第一个字节偏移地址ip入栈,再转到偏移地址为ax(16位reg)处执行指令。编译无法通过,只能理论分析.检测点(第195页)(1)下面的程序执行后,ax中的数值为多少?assume cs:codestack segment dw 8 dup (0)stack endscode seg

    22、mentstart: mov ax, stack mov ss, ax mov sp,16 mov ds, ax mov ax,0 call word ptr ds:0eh inc ax inc axinc ax mov ax,4c00hint 21hcode endsend start 当程序执行call word ptr ds:0EH语句时,相当于进行: 1: PUSH IP(此时IP的值为CALL语句下一条语句的偏移地址,也就是INC AX的偏移地址) 2: JMP WORD PTR SS(因为DS等于SS):0EH,此时程序跳转到CS:SS:OEH处执行,因为 SS:0EH的值为0,所

    23、以跳转到CS:0处开始执行,也就是程序的第一条语句MOV AX, STACK,当程序再一次执行到call word ptr ds:0EH时,又进行上面的两步,但是此时SS:OEH的值已经不是0了,而是上一次执 行PUSH IP时,压入的IP的值,而这个IP正是CALL语句下一条语句的偏移地址,也就是INC AX的偏移地址.所以程序跳转到语句INC AX处执行,所以AX的值为3. (2)下面的程序执行后,ax和bx中的数值为多少?assume cs:codesgstack segment dw 8 dup(0)stack endscodesg segmentstart: mov ax, stac

    24、k mov ss, ax mov sp,10h mov word ptr ss:0,offset s ;(ss:0)=1ah mov ss:2,cs ;(ss:2)=cs call dword ptr ss:0 ;cs入栈,ip=19h入栈,转到cs:1ah处执行指令 ; ss:0ch = 19h ss:0eh = cs nops: mov ax, offset s ;ax=1ah sub ax, ss:0ch ;ax=1ah-(ss:0ch)=1ah-19h=1 mov bx, cs ;bx=cs0c5bh sub bx, ss:0eh ;bx=cs-cs=0 mov ax,4c00h in

    25、t 21hcodesg endsend start检测点(第216页)写出下面每条指令执行后,ZF、PF、SF、等标志位的值。 sub al,al al=0h ZF=1 PF=1 SF=0 mov al,1 al=1h ;mov 指令不改变标志位 ZF=1 PF=1 SF=0 push ax ax=1h ;push 指令不改变标志位 ZF=1 PF=1 SF=0 pop bx bx=1h ;pop 指令不改变标志位 ZF=1 PF=1 SF=0 add al,bl al=2h ;al = 00000010b ZF=0 PF=0 SF=0 add al,10 al=12h ;al = 00001

    26、010b ZF=0 PF=1 SF=0 mul al ax=144h ;ax = b ZF=0 PF=1 SF=0检测点(第219页)写出下面每条指令执行后,ZF、PF、SF、CF、OF等标志位的值。 al CF OF SF ZF PFsub al, al 0h 0000 0000b 0 0 0 1 1mov al,10h 10h 0010 0000b 0 0 0 1 1add al,90h a0h 1010 0000b 0 0 1 0 1mov al,80h 80h 1000 0000b 0 0 1 0 1add al,80h 0h 0000 0000b 1 1 0 1 1mov al,0f

    27、ch 0fch 1111 1100b 1 1 0 1 1add al,05h 1h 0000 0001b 1 0 0 0 0mov al,7dh 7dh 1111 1101b 1 0 0 0 0add al,0bh 88h 1000 1000b 0 1 1 0 1检测点涉及的相关内容:CF是flag的第0位,进位标志位,记录无符号运算结果是否有进/借位,结果有进/借位时,SF=1OF是flag的第11位,溢出标志位,记录有符号运算结果是否溢出,结果溢出时,OF=1正数相加超出127,负数相加超出-128,两种情况OF均置为1SF是flag的第7位,符号标志位,记录有符号运算结果是否为负数,结果

    28、为负数时,SF=1ZF是flag的第6位,零标志位,记录指令执行后结果是否为0,结果为0时,ZF=1PF是flag的第2位,奇偶标志位,记录指令执行后结果二进制中1的个数是否为偶数,结果为偶数时,PF=1add、sub、mul、div、inc、or、and等运算指令影响标志寄存器mov、push、pop等传送指令对标志寄存器没影响。检测点(第229页)(1)补全下面的程序,统计F000:0处32个字节中,大小在32,128的数据个数。 mov ax,0f000h mov ds, ax mov bx,0 ;ds: bx指向第一个字节 mov dx,0 ;初始化累加器 mov cx,32s: mo

    29、v al,bx cmp al,32 ;和32进行比较 jb s0 ;如果低于al转到s0,继续循环 cmp al,128 ;和128进行比较 ja s0 ;如果高于al转到s0,继续循环 inc dxs0: inc bxloop s(2)补全下面的程序,统计F000:0处32个字节中,大小在(32,128)的数据个数。 mov ax,0f000h mov ds,ax mov bx,0 ;ds:bx指向第一个字节 mov dx,0 ;初始化累加器 mov cx,32s: mov al,bx cmp al,32 ;和32进行比较 jna s0 ;如果不高于al转到s0,继续循环 cmp al,128 ;和128进行比较 jnb s0 ;如果不低于al转到s0,继续循环 inc dxs0:


    注意事项

    本文(汇编语言课后习题解答.docx)为本站会员主动上传,冰点文库仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对上载内容本身不做任何修改或编辑。 若此文所含内容侵犯了您的版权或隐私,请立即通知冰点文库(点击联系客服),我们立即给予删除!

    温馨提示:如果因为网速或其他原因下载失败请重新下载,重复下载不扣分。




    关于我们 - 网站声明 - 网站地图 - 资源地图 - 友情链接 - 网站客服 - 联系我们

    copyright@ 2008-2023 冰点文库 网站版权所有

    经营许可证编号:鄂ICP备19020893号-2


    收起
    展开