没有合适的资源?快使用搜索试试~ 我知道了~
首页王爽《汇编语言》第三版答案
王爽《汇编语言》第三版答案

检测点 1.1 (1) 1 个 CPU 的寻址能力为 8KB,那么它的地址总线的宽度为 13 位。 (2) 1KB 的存储器有 1024 个存储单元,存储单元的编号从 0 到 1023 。 (3) 1KB 的存储器可以存储 8192(2^13) 个 bit, 1024 个 Byte。 (4) 1GB 是 1073741824 (2^30) 个 Byte、 1MB 是 1048576(2^20) 个 Byte、 1KB 是 1024 (2^10)个 Byte。
资源详情
资源评论
资源推荐

检测点 1.1
(1)1 个 CPU 的寻址能力为 8KB,那么它的地址总线的宽度为 13 位。
(2)1KB 的存储器有 1024 个存储单元,存储单元的编号从 0 到 1023 。
(3)1KB 的存储器可以存储 8192(2^13) 个 bit, 1024 个 Byte。
(4)1GB 是 1073741824 (2^30) 个 Byte、1MB 是 1048576(2^20) 个 Byte、1KB 是 1024
(2^10)个 Byte。
(5)8080、8088、80296、80386 的地址总线宽度分别为 16 根、20 根、24 根、32 根,则
它们的寻址能力分别为: 64 (KB)、 1 (MB)、 16 (MB)、 4 (GB)。
(6)8080、8088、8086、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=2^N,N=13。
(2)存储器的容量是以字节为最小单位来计算的,1KB=1024B。
(3)8Bit=1Byte,1024Byte=1KB(1KB=1024B=1024B*8Bit)。
(4)1GB=1073741824B(即 2^30)1MB=1048576B(即 2^20)1KB=1024B(即 2^10)。
(5)一个 CPU 有 N 根地址线,则可以说这个 CPU 的地址总线的宽度为 N。这样的 CPU 最
多可以寻找 2 的 N 次方个内存单元。(一个内存单元=1Byte)。
(6)8 根数据总线一次可以传送 8 位二进制数据(即一个字节)。
(7)8086 的数据总线宽度为 16 根(即一次传送的数据为 2B)1024B/2B=512,同理
1024B/4B=256。
(8)在存储器中指令和数据没有任何区别,都是二进制信息。
检测点 2.1
(1) 写出每条汇编指令执行后相关寄存器中的值。
mov ax,62627 AX=F4A3H
mov ah,31H AX=31A3H
mov al,23H AX=3123H
add ax,ax AX=6246H
mov bx,826CH BX=826CH
mov cx,ax CX=6246H
mov ax,bx AX=826CH

add ax,bx AX=04D8H
mov al,bh AX=0482H
mov ah,bl AX=6C82H
add ah,ah AX=D882H
add al,6 AX=D888H
add al,al AX=D810H
mov ax,cx AX=6246H
检测点 2.1
(2) 只能使用目前学过的汇编指令,最多使用 4 条指令,编程计算 2 的 4 次方。
mov ax,2 AX=2
add ax,ax AX=4
add ax,ax AX=8
add ax,ax AX=16
检测点 2.2
(1) 给定段地址为 0001H,仅通过变化偏移地址寻址,CPU 的寻址范围为 0010H 到 1000FH 。
解题过程:
物理地址=SA*16+EA
EA 的变化范围为 0h~ffffh
物理地址范围为(SA*16+0h)~(SA*16+ffffh)
现在 SA=0001h,那么寻址范围为
(0001h*16+0h)~(0001h*16+ffffh)
=0010h~1000fh
检测点 2.2
(2) 有一数据存放在内存 20000H 单元中,现给定段地址为 SA,若想用偏移地址寻到此单元。
则 SA 应满足的条件是:最小为 1001H ,最大为 2000H 。
当段地址给定为 1001H 以下和 2000H 以上,CPU 无论怎么变化偏移地址都无法寻到
20000H 单元。
解题过程:
物理地址=SA*16+EA
20000h=SA*16+EA

SA=(20000h-EA)/16=2000h-EA/16
EA 取最大值时,SA=2000h-ffffh/16=1001h,SA 为最小值
EA 取最小值时,SA=2000h-0h/16=2000h,SA 为最大值
检测点 2.3
下面的 3 条指令执行后,cpu 几次修改 IP?都是在什么时候?最后 IP 中的值是多少?
mov ax,bx
sub ax,ax
jmp ax
答:一共修改四次
第一次:读取 mov ax,bx 之后
第二次:读取 sub ax,ax 之后
第三次:读取 jmp ax 之后
第四次:执行 jmp ax 修改 IP
最后 IP 的值为 0000H,因为最后 ax 中的值为 0000H,所以 IP 中的值也为 0000H
检测点 3.1
(1) 在 DEBUG 中,用 "D 0:0 lf" 查看内存,结果如下:
0000:0000 70 80 F0 30 EF 60 30 E2-00 80 80 12 66 20 22 60
0000:0010 62 26 E6 D6 CC 2E 3C 3B-AB BA 00 00 26 06 66 88
下面的程序执行前,AX=0,BX=0,写出每条汇编指令执行完后相关寄存器中的值
mov ax,1
mov ds,ax
mov ax,[0000] ax= 2662H
mov bx,[0001] bx= E626H
mov ax,bx ax= E626H
mov ax,[0000] ax= 2662H
mov bx,[0002] bx= D6E6H
add ax,bx ax= FD48H
add ax,[0004] ax= 2C14H
mov ax,0 ax= 0
mov al,[0002] ax= 00e6H
mov bx,0 bx= 0
mov bl,[000c] bx= 0026H

add al,bl ax= 000CH
检测点 3.1
(2) 内存中的情况如图 3.6 所示
各寄存器的初始值:cs=2000h,ip=0,ds=1000h,ax=0,bx=0;
检测点 3.2
(1)补全下面的程序,使其可以将 10000H-1000FH 中的 8 个字,逆序拷贝到 20000H-2000FH
中。
mov ax,1000H
mov ds,ax
mov ax,2000H
mov ss,ax
mov sp,10h
push [0]
push [2]
push [4]
push [6]
push [8]
push [A]
push [C]
push [E]
检测点 3.2
(2)补全下面的程序,使其可以将 10000H-1000FH 中的 8 个字,逆序拷贝到 20000H-2000FH
中。
mov ax,2000H
mov ds,ax
mov ax,1000H
mov ss,ax
mov sp,0
pop [e]
pop [c]
pop [a]
pop [8]
pop [6]
pop [4]

pop [2]
pop [0]
检测点 6.1
(1)下面的程序实现依次用内存 0:0~0:15 单元中的内容改写程序中的数据,完成程序:
assume cs:codesg
codesg segment
dw 0123h,0456h,0789h,0abch,0defh,0fedh,0cbah,0987h
start: 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 21h
codesg ends
end start
检测点 6.1
(2)下面的程序实现依次用内存 0:0~0:15 单元中的内容改写程序中的数据,数据的传送用
栈来进行。栈空间设置在程序内。完成程序:
assume cs:codesg
codesg segment
dw 0123h,0456h,0789h,0abch,0defh,0fedh,0cbah,0987h
dw 0,0,0,0,0,0,0,0,0,0
start: mov ax, codesg ;或 mov ax, cs
mov ss,ax
mov sp, 24h ;或 mov sp, 36 ;(第一版填 1ah 或 26)
mov ax,0
mov ds,ax
mov bx,0
mov cx,8
s: push [bx]
剩余20页未读,继续阅读



安全验证
文档复制为VIP权益,开通VIP直接复制

评论2