汇编语言王爽第二版-课后答案以及解析
生活随笔
收集整理的這篇文章主要介紹了
汇编语言王爽第二版-课后答案以及解析
小編覺(jué)得挺不錯(cuò)的,現(xiàn)在分享給大家,幫大家做個(gè)參考.
檢測(cè)點(diǎn)1.1 (1)1個(gè)CPU的尋址能力為8KB,那么它的地址總線的寬度為 13位。
(2)1KB的存儲(chǔ)器有 1024 個(gè)存儲(chǔ)單元,存儲(chǔ)單元的編號(hào)從 0 到 1023 。
(3)1KB的存儲(chǔ)器可以存儲(chǔ) 8192(2^13) 個(gè)bit, 1024個(gè)Byte。
(4)1GB是 1073741824 (2^30) 個(gè)Byte、1MB是 1048576(2^20) 個(gè)Byte、1KB是 1024(2^10)個(gè)Byte。
(5)8080、8088、80296、80386的地址總線寬度分別為16根、20根、24根、32根,則它們的尋址能力分別為: 64 (KB)、 1 (MB)、 16 (MB)、 4 (GB)。
(6)8080、8088、8086、80286、80386的數(shù)據(jù)總線寬度分別為8根、8根、16根、16根、32根。則它們一次可以傳送的數(shù)據(jù)為: 1 (B)、 1 (B)、 2 (B)、 2 (B)、 4 (B)。
(7)從內(nèi)存中讀取1024字節(jié)的數(shù)據(jù),8086至少要讀 512 次,80386至少要讀 256 次。
(8)在存儲(chǔ)器中,數(shù)據(jù)和程序以 二進(jìn)制 形式存放。解題過(guò)程:
(1)1KB=1024B,8KB=1024B*8=2^N,N=13。
(2)存儲(chǔ)器的容量是以字節(jié)為最小單位來(lái)計(jì)算的,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)一個(gè)CPU有N根地址線,則可以說(shuō)這個(gè)CPU的地址總線的寬度為N。這樣的CPU最多可以尋找2的N次方個(gè)內(nèi)存單元。(一個(gè)內(nèi)存單元=1Byte)。
(6)8根數(shù)據(jù)總線一次可以傳送8位二進(jìn)制數(shù)據(jù)(即一個(gè)字節(jié))。
(7)8086的數(shù)據(jù)總線寬度為16根(即一次傳送的數(shù)據(jù)為2B)1024B/2B=512,同理1024B/4B=256。
(8)在存儲(chǔ)器中指令和數(shù)據(jù)沒(méi)有任何區(qū)別,都是二進(jìn)制信息。
檢測(cè)點(diǎn) 2.1
(1) 寫(xiě)出每條匯編指令執(zhí)行后相關(guān)寄存器中的值。
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
檢測(cè)點(diǎn)2.1
(2) 只能使用目前學(xué)過(guò)的匯編指令,最多使用4條指令,編程計(jì)算2的4次方。
mov ax,2 AX=2
add ax,ax AX=4
add ax,ax AX=8
add ax,ax AX=16 檢測(cè)點(diǎn)2.2
(1) 給定段地址為0001H,僅通過(guò)變化偏移地址尋址,CPU的尋址范圍為 0010H 到 1000FH 。解題過(guò)程:
物理地址=SA*16+EA
EA的變化范圍為0h~ffffh
物理地址范圍為(SA*16+0h)~(SA*16+ffffh)
現(xiàn)在SA=0001h,那么尋址范圍為
(0001h*16+0h)~(0001h*16+ffffh)
=0010h~1000fh
檢測(cè)點(diǎn)2.2
(2) 有一數(shù)據(jù)存放在內(nèi)存20000H單元中,現(xiàn)給定段地址為SA,若想用偏移地址尋到此單元。則SA應(yīng)滿足的條件是:最小為 1001H ,最大為 2000H 。
當(dāng)段地址給定為 1001H 以下和 2000H 以上,CPU無(wú)論怎么變化偏移地址都無(wú)法尋到20000H單元。解題過(guò)程:
物理地址=SA*16+EA
20000h=SA*16+EA
SA=(20000h-EA)/16=2000h-EA/16
EA取最大值時(shí),SA=2000h-ffffh/16=1001h,SA為最小值
EA取最小值時(shí),SA=2000h-0h/16=2000h,SA為最大值 檢測(cè)點(diǎn)2.3
下面的3條指令執(zhí)行后,cpu幾次修改IP?都是在什么時(shí)候?最后IP中的值是多少?
mov ax,bx
sub ax,ax
jmp ax 答:一共修改四次
第一次:讀取mov ax,bx之后
第二次:讀取sub ax,ax之后
第三次:讀取jmp ax之后
第四次:執(zhí)行jmp ax修改IP
最后IP的值為0000H,因?yàn)樽詈骯x中的值為0000H,所以IP中的值也為0000H
檢測(cè)點(diǎn)3.1
(1) 在DEBUG中,用 "D 0:0 lf" 查看內(nèi)存,結(jié)果如下:
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
下面的程序執(zhí)行前,AX=0,BX=0,寫(xiě)出每條匯編指令執(zhí)行完后相關(guān)寄存器中的值
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
檢測(cè)點(diǎn)3.1
(2) 內(nèi)存中的情況如圖3.6所示
各寄存器的初始值:cs=2000h,ip=0,ds=1000h,ax=0,bx=0;
檢測(cè)點(diǎn)3.2
(1)補(bǔ)全下面的程序,使其可以將10000H-1000FH中的8個(gè)字,逆序拷貝到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]
檢測(cè)點(diǎn)3.2
(2)補(bǔ)全下面的程序,使其可以將10000H-1000FH中的8個(gè)字,逆序拷貝到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]
檢測(cè)點(diǎn)6.1
(1)下面的程序?qū)崿F(xiàn)依次用內(nèi)存0:0~0:15單元中的內(nèi)容改寫(xiě)程序中的數(shù)據(jù),完成程序:
assume cs:codesg
codesg segmentdw 0123h,0456h,0789h,0abch,0defh,0fedh,0cbah,0987h
start: mov ax,0mov ds,axmov bx,0mov cx,8s: mov ax,[bx]mov cs:[bx],axadd bx,2loop smov ax,4c00hint 21h
codesg ends
end start
檢測(cè)點(diǎn)6.1
(2)下面的程序?qū)崿F(xiàn)依次用內(nèi)存0:0~0:15單元中的內(nèi)容改寫(xiě)程序中的數(shù)據(jù),數(shù)據(jù)的傳送用棧來(lái)進(jìn)行。棧空間設(shè)置在程序內(nèi)。完成程序:
assume cs:codesg
codesg segmentdw 0123h,0456h,0789h,0abch,0defh,0fedh,0cbah,0987hdw 0,0,0,0,0,0,0,0,0,0
start: mov ax, codesg ;或mov ax, csmov ss,axmov sp, 24h ;或mov sp, 36 ;(第一版填1ah或26)mov ax,0mov ds,axmov bx,0mov cx,8s: push [bx]pop cs:[bx] ;或 pop ss:[bx]add bx,2 loop smov ax,4c00hint 21h
codesg ends
end start
(1)程序如下。
assume cs:code
data segmentdw 2 dup (0)
data ends
code segmentstart: mov ax,dtatmov ds,axmov bx,0jmp word ptr [bx+1]
code ends
end start
若要使jmp指令執(zhí)行后,CS:IP指向程序的第一條指令,在data段中應(yīng)該定義哪些數(shù)據(jù)?答案①db 3 dup (0)
答案②dw 2 dup (0)
答案③dd 0
jmp word ptr [bx+1]為段內(nèi)轉(zhuǎn)移,要CS:IP指向程序的第一條指令,應(yīng)設(shè)置ds:[bx+1]的字單元(2個(gè)字節(jié))存放數(shù)據(jù)應(yīng)為0,則(ip)=ds:[bx+1]=0
簡(jiǎn)單來(lái)說(shuō)就是,只要ds:[bx+1]起始地址的兩個(gè)字節(jié)為0就可以了檢測(cè)點(diǎn)9.1
(1)程序如下。
assume cs:code
data segmentdd 12345678h
data ends
code segmentstart: mov ax,datamov ds,axmov bx,0mov [bx], bx ;或mov [bx], word ptr 0 ;或mov [bx], offset startmov [bx+2], cs ;或mov [bx+2], cs ;或mov [bx+2], seg code jmp dword ptr ds:[0]
code ends
end start
補(bǔ)全程序,使用jmp指令執(zhí)行后,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]為段間轉(zhuǎn)移,(cs)=(內(nèi)存單元地址+2),(ip)=(內(nèi)存單元地址),要CS:IP指向程序的第一條指令,第一條程序地址cs:0,應(yīng)設(shè)置CS:IP指向cs:0
程序中的mov [bx],bx這條指令,是將ip設(shè)置為0
mov [bx+2],cs,將cs這個(gè)段地址放入內(nèi)存單元
執(zhí)行后,cs應(yīng)該不變,只調(diào)整ip為0,(ip)=ds:[0]=0
檢測(cè)點(diǎn)9.1
(3)用Debug查看內(nèi)存,結(jié)果如下:
2000:1000 BE 00 06 00 00 00 ......
則此時(shí),CPU執(zhí)行指令:
mov ax,2000h
mov es,ax
jmp dword ptr es:[1000h]
后,(cs)= 0006H ,(ip)= 00BEH解析:
jmp dword ptr為段間轉(zhuǎn)移,高位存放段地址,低位存放偏移地址
(cs)=(內(nèi)存單元地址+2),(ip)=(內(nèi)存單元地址)根據(jù)書(shū)P16,對(duì)于寄存器AX,AH為高位(前1字節(jié)為高位),AL為低位(后1字節(jié)為低位)
推算出(內(nèi)存單元地址)=00beh,(內(nèi)存單元地址+2)=0006h
根據(jù)書(shū)P182,高位存放段地址(后2個(gè)字節(jié)為高位),低位存放偏移地址(前2個(gè)字節(jié)為低位)
(cs)=(內(nèi)存單元地址+2),(ip)=(內(nèi)存單元地址)
推算出(cs)=0006h,(ip)=00beh
檢測(cè)點(diǎn)9.2
補(bǔ)全編程,利用jcxz指令,實(shí)現(xiàn)在內(nèi)存2000H段中查找第一個(gè)值為0的字節(jié),找到后,將它的偏移地址存儲(chǔ)在dx中。
assume cs:code
code segmentstart: mov ax,2000hmov ds,axmov bx,0s: mov ch,0 mov cl,[bx]jcxz ok ;當(dāng)cx=0時(shí),CS:IP指向OKinc bx jmp short sok: mov dx,bxmov ax ,4c00hint 21h
code ends
end start
檢測(cè)點(diǎn)9.3
補(bǔ)全編程,利用loop指令,實(shí)現(xiàn)在內(nèi)存2000H段中查找第一個(gè)值為0的字節(jié),找到后,將它的偏移地址存儲(chǔ)在dx中。
assume cs:code
code segment
start: mov ax,2000hmov ds,axmov bx,0s:mov cl,[bx]mov ch,0inc cx inc bxloop sok:dec bxmov dx,bxmov ax,4c00hint 21h
code ends
end start書(shū)P101,執(zhí)行l(wèi)oop s時(shí),首先要將(cx)減1。
“l(fā)oop 標(biāo)號(hào)”相當(dāng)于
dec cx
if((cx)≠0) jmp short 標(biāo)號(hào)
檢測(cè)點(diǎn)10.1
補(bǔ)全程序,實(shí)現(xiàn)從內(nèi)存1000:0000處開(kāi)始執(zhí)行指令。
assume cs:code
stack segmentdb 16 dup (0)
stack ends
code segment
start: mov ax,stackmov ss,axmov sp,16mov ax, 1000hpush axmov ax, 0 push axretf
code ends
end start執(zhí)行reft指令時(shí),相當(dāng)于進(jìn)行:
pop ip
pop cs
根據(jù)棧先進(jìn)后出原則,應(yīng)先將段地址cs入棧,再將偏移地址ip入棧。檢測(cè)點(diǎn)10.2
下面的程序執(zhí)行后,ax中的數(shù)值為多少?
內(nèi)存地址 機(jī)器碼 匯編指令 執(zhí)行后情況
1000:0 b8 00 00 mov ax,0 ax=0 ip指向1000:3
1000:3 e8 01 00 call s pop ip ip指向1000:7
1000:6 40 inc ax
1000:7 58 s:pop ax ax=6用debug進(jìn)行跟蹤確認(rèn),“call 標(biāo)號(hào)”是將該指令后的第一個(gè)字節(jié)偏移地址入棧,再轉(zhuǎn)到標(biāo)號(hào)處執(zhí)行指令。assume cs:code
code segment
start: mov ax,0call sinc ax
s: pop axmov ax,4c00hint 21h
code ends
end start檢測(cè)點(diǎn)10.3
下面的程序執(zhí)行后,ax中的數(shù)值為多少?
內(nèi)存地址 機(jī)器碼 匯編指令 執(zhí)行后情況
1000:0 b8 00 00 mov ax,0 ax=0,ip指向1000:3
1000:3 9a 09 00 00 10 call far ptr s pop cs,pop ip,ip指向1000:9
1000:8 40 inc ax
1000:9 58 s:pop ax ax=8hadd ax,ax ax=10hpop bx bx=1000hadd ax,bx ax=1010h用debug進(jìn)行跟蹤確認(rèn),“call far ptr s”是先將該指令后的第一個(gè)字節(jié)段地址cs=1000h入棧,再將偏移地址ip=8h入棧,最后轉(zhuǎn)到標(biāo)號(hào)處執(zhí)行指令。
出棧時(shí),根據(jù)棧先進(jìn)后出的原則,先出的為ip=8h,后出的為cs=1000h
檢測(cè)點(diǎn)10.4
下面的程序執(zhí)行后,ax中的數(shù)值為多少?
內(nèi)存地址 機(jī)器碼 匯編指令 執(zhí)行后情況
1000:0 b8 06 00 mov ax,6 ax=6,ip指向1000:3
1000:3 ff d0 call ax pop ip,ip指向1000:6
1000:5 40 inc ax
1000:6 58 mov bp,sp bp=sp=fffehadd ax,[bp] ax=[6+ds:(fffeh)]=6+5=0bh用debug進(jìn)行跟蹤確認(rèn),“call ax(16位reg)”是先將該指令后的第一個(gè)字節(jié)偏移地址ip入棧,再轉(zhuǎn)到偏移地址為ax(16位reg)處執(zhí)行指令。檢測(cè)點(diǎn)10.5
(1)下面的程序執(zhí)行后,ax中的數(shù)值為多少?
assume cs:code
stack segmentdw 8 dup (0)
stack ends
code segment
start: mov ax,stackmov ss,axmov sp,16mov ds,axmov ax,0call word ptr ds:[0eh]inc axinc axinc axmov ax,4c00hint 21h
code ends
end start推算:
執(zhí)行call word ptr ds:[0eh]指令時(shí),先cs入棧,再ip=11入棧,最后ip轉(zhuǎn)移到(ds:[0eh])。(ds:[0eh])=11h,執(zhí)行inc ax……最終ax=3題中特別關(guān)照別用debug跟蹤,跟蹤結(jié)果不一定正確,但還是忍不住去試試,看是什么結(jié)果。
根據(jù)單步跟蹤發(fā)現(xiàn),執(zhí)行call word ptr ds:[0eh]指令時(shí),顯示ds:[0eh]=065D。
ds:0000~ds:0010不是已設(shè)置成stack數(shù)據(jù)段了嘛,不是應(yīng)該全都是0的嘛。
于是進(jìn)行了更詳細(xì)的單步跟蹤,發(fā)現(xiàn)初始數(shù)據(jù)段中數(shù)據(jù)確實(shí)為0,但執(zhí)行完mov ss,ax;mov sp,16這兩條指令后,數(shù)據(jù)段中數(shù)據(jù)發(fā)生改變。這是為什么呢?中斷唄~~~~
檢測(cè)點(diǎn)10.5
(2)下面的程序執(zhí)行后,ax和bx中的數(shù)值為多少?
assume cs:codesg
stack segmentdw 8 dup(0)
stack ends
codesg segment
start:mov ax,stackmov ss,axmov sp,10hmov word ptr ss:[0],offset s ;(ss:[0])=1ahmov ss:[2],cs ;(ss:[2])=cscall dword ptr ss:[0] ;cs入棧,ip=19h入棧,轉(zhuǎn)到cs:1ah處執(zhí)行指令;(ss:[4])=cs,(ss:[6])=ipnop
s: mov ax,offset s ;ax=1ahsub ax,ss:[0ch] ;ax=1ah-(ss:[0ch])=1ah-19h=1mov bx,cs ;bx=cs=0c5bhsub bx,ss:[0eh] ;bx=cs-cs=0mov ax,4c00hint 21h
codesg ends
end start
檢測(cè)點(diǎn)11.1
寫(xiě)出下面每條指令執(zhí)行后,ZF、PF、SF、等標(biāo)志位的值。
sub al,al al=0h ZF=1 PF=1 SF=0
mov al,1 al=1h ZF=1 PF=1 SF=0
push ax ax=1h ZF=1 PF=1 SF=0
pop bx bx=1h ZF=1 PF=1 SF=0
add al,bl al=2h ZF=0 PF=0 SF=0
add al,10 al=12h ZF=0 PF=1 SF=0
mul al ax=144h ZF=0 PF=1 SF=0檢測(cè)點(diǎn)涉及的相關(guān)內(nèi)容:
ZF是flag的第6位,零標(biāo)志位,記錄指令執(zhí)行后結(jié)果是否為0,結(jié)果為0時(shí),ZF=1
PF是flag的第2位,奇偶標(biāo)志位,記錄指令執(zhí)行后結(jié)果二進(jìn)制中1的個(gè)數(shù)是否為偶數(shù),結(jié)果為偶數(shù)時(shí),PF=1
SF是flag的第7位,符號(hào)標(biāo)志位,記錄有符號(hào)運(yùn)算結(jié)果是否為負(fù)數(shù),結(jié)果為負(fù)數(shù)時(shí),SF=1
add、sub、mul、div 、inc、or、and等運(yùn)算指令影響標(biāo)志寄存器
mov、push、pop等傳送指令對(duì)標(biāo)志寄存器沒(méi)影響。檢測(cè)點(diǎn)11.2
寫(xiě)出下面每條指令執(zhí)行后,ZF、PF、SF、CF、OF等標(biāo)志位的值。al CF OF SF ZF PF
sub al,al 0h/0000 0000b 0 0 0 1 1
mov al,10h 10h/0010 0000b 0 0 0 1 1
add al,90h a0h/1010 0000b 0 0 1 0 1
mov al,80h 80h/1000 0000b 0 0 1 0 1
add al,80h 0h/0000 0000b 1 1 0 1 1
mov al,0fch 0fch/1111 1100b 1 1 0 1 1
add al,05h 1h/0000 0001b 1 0 0 0 0
mov al,7dh 7dh/1111 1101b 1 0 0 0 0
add al,0bh 88h/1000 1000b 0 1 1 0 1檢測(cè)點(diǎn)涉及的相關(guān)內(nèi)容:
ZF是flag的第6位,零標(biāo)志位,記錄指令執(zhí)行后結(jié)果是否為0,結(jié)果為0時(shí),ZF=1
PF是flag的第2位,奇偶標(biāo)志位,記錄指令執(zhí)行后結(jié)果二進(jìn)制數(shù)中1的個(gè)數(shù)是否為偶數(shù),結(jié)果為偶數(shù)時(shí),PF=1
SF是flag的第7位,符號(hào)標(biāo)志位,記錄有符號(hào)運(yùn)算結(jié)果是否為負(fù)數(shù),結(jié)果為負(fù)數(shù)時(shí),SF=1
CF是flag的第0位,進(jìn)位標(biāo)志位,記錄無(wú)符號(hào)運(yùn)算結(jié)果是否有進(jìn)/借位,結(jié)果有進(jìn)/借位時(shí),SF=1
OF是flag的第11位,溢出標(biāo)志位,記錄有符號(hào)運(yùn)算結(jié)果是否溢出,結(jié)果溢出時(shí),OF=1
add、sub、mul、div 、inc、or、and等運(yùn)算指令影響flag
mov、push、pop等傳送指令對(duì)flag沒(méi)影響檢測(cè)點(diǎn)11.3
(1)補(bǔ)全下面的程序,統(tǒng)計(jì)F000:0處32個(gè)字節(jié)中,大小在[32,128]的數(shù)據(jù)個(gè)數(shù)。mov ax,0f000hmov ds,axmov bx,0 ;ds:bx指向第一個(gè)字節(jié)mov dx,0 ;初始化累加器mov cx,32
s: mov al,[bx]cmp al,32 ;和32進(jìn)行比較jb s0 ;如果低于al轉(zhuǎn)到s0,繼續(xù)循環(huán)cmp al,128 ;和128進(jìn)行比較ja s0 ;如果高于al轉(zhuǎn)到s0,繼續(xù)循環(huán)inc dx
s0: inc bxloop s[32,128]是閉區(qū)間,包括兩端點(diǎn)的值
(32,128)是開(kāi)區(qū)間,不包括兩端點(diǎn)的值
檢測(cè)點(diǎn)11.3
(2)補(bǔ)全下面的程序,統(tǒng)計(jì)F000:0處32個(gè)字節(jié)中,大小在(32,128)的數(shù)據(jù)個(gè)數(shù)。mov ax,0f000hmov ds,axmov bx,0 ;ds:bx指向第一個(gè)字節(jié)mov dx,0 ;初始化累加器mov cx,32
s: mov al,[bx]cmp al,32 ;和32進(jìn)行比較jna s0 ;如果不高于al轉(zhuǎn)到s0,繼續(xù)循環(huán)cmp al,128 ;和128進(jìn)行比較jnb s0 ;如果不低于al轉(zhuǎn)到s0,繼續(xù)循環(huán)inc dx
s0: inc bxloop s[32,128]是閉區(qū)間,包括兩端點(diǎn)的值
(32,128)是開(kāi)區(qū)間,不包括兩端點(diǎn)的值檢測(cè)點(diǎn)11.4
下面指令執(zhí)行后,(ax)= 45h
mov ax,0
push ax
popf
mov ax,0fff0h
add ax,0010h
pushf
pop ax
and al,11000101B
and ah,00001000B推算過(guò)程:
popf后,標(biāo)志寄存器中,本章節(jié)介紹的那些標(biāo)志位都為0(但是此時(shí)標(biāo)志寄存器并不是所有位置都為0,這個(gè)不用關(guān)心,沒(méi)學(xué)過(guò)的位置用*先代替),向下進(jìn)行,那么pushf將計(jì)算后的當(dāng)時(shí)狀態(tài)的標(biāo)志寄存器入棧,然后pop給ax,這是ax是寄存器的值(這個(gè)值中包含了我們的*號(hào)),接下來(lái)就是對(duì)那些沒(méi)有學(xué)過(guò)的標(biāo)志位的屏蔽操作,這就是最后兩條指令的意義所在,將不確定的位置都?xì)w0,那么只剩下我們能夠確定的位置了,所以,結(jié)果就可以推理出來(lái)了。
mov ax,0
push ax
popf
mov ax,0fff0h
add ax,0010h
pushf
pop ax 0 0 0 0 of df if tf sf zf 0 af 0 pf 0 cf0 0 0 0 0 0 * * 0 1 0 * 0 1 0 1ax=flag=000000** 010*0101b
and al,11000101B al=01000101b=45h
and ah,00001000B ah=00000000b=0h檢測(cè)點(diǎn)12.1
(1)用debug查看內(nèi)存,情況如下:
0000:0000 68 10 A7 00 8B 01 70 00-16 00 9D 03 8B 01 70 00
則3號(hào)中斷源對(duì)應(yīng)的中斷處理程序入口的偏移地址的內(nèi)存單位的地址為: 0070:018b檢測(cè)點(diǎn)涉及相關(guān)內(nèi)容:
一個(gè)表項(xiàng)存放一個(gè)中斷向量,也就是一個(gè)中斷處理程序的入口地址,這個(gè)入口地址包括段地址和偏移地址,一個(gè)表項(xiàng)占兩個(gè)字,高地址存放段地址,低地址存放偏移地址檢測(cè)點(diǎn)12.1
(2)
存儲(chǔ)N號(hào)中斷源對(duì)應(yīng)的中斷處理程序入口的偏移地址的內(nèi)存單元的地址為: 4N
存儲(chǔ)N號(hào)中斷源對(duì)應(yīng)的中斷處理程序入口的段地址的內(nèi)存單元的地址為: 4N+2檢測(cè)點(diǎn)涉及相關(guān)內(nèi)容:
一個(gè)表項(xiàng)存放一個(gè)中斷向量,也就是一個(gè)中斷處理程序的入口地址,這個(gè)入口地址包括段地址和偏移地址,一個(gè)表項(xiàng)占兩個(gè)字,高地址存放段地址,低地址存放偏移地址
檢測(cè)點(diǎn)13.17ch中斷例程如下:
lp: push bpmov bp,spdec cxjcxz lpretadd [bp+2],bx
lpret: pop bpiret(1)在上面的內(nèi)容中,我們用7ch中斷例程實(shí)現(xiàn)loop的功能,則上面的7ch中斷例程所能進(jìn)行的最大轉(zhuǎn)移位移是多少?最大位移是FFFFH
檢測(cè)點(diǎn)13.1
(2)用7ch中斷例程完成jmp near ptr s指令功能,用bx向中斷例程傳送轉(zhuǎn)移位移。應(yīng)用舉例:在屏幕的第12行,顯示data段中以0結(jié)尾的字符串。
assume cs:code
data segmentdb 'conversation',0
data ends
code segment
start:mov ax,datamov ds,axmov si,0mov ax,0b800hmov es,axmov di,12*160
s: cmp byte ptr [si],0je okmov al,[si]mov es:[di],alinc siadd di,2mov bx,offset s-offset okint 7ch
ok: mov ax,4c00hint 21h
code ends
end startjmp near ptr s指令的功能為:(ip)=(ip)+16位移,實(shí)現(xiàn)段內(nèi)近轉(zhuǎn)移assume cs:code
code segment
start:
mov ax,cs
mov ds,ax
mov si,offset do0 ;設(shè)置ds:si指向源地址
mov ax,0
mov es,ax
mov di,200h ;設(shè)置es:di指向目標(biāo)地址
mov cx,offset do0end-offset do0 ;設(shè)置cx為傳輸長(zhǎng)度
cld ;設(shè)置傳輸方向?yàn)檎?
rep movsb
mov ax,0
mov es,ax
mov word ptr es:[7ch*4],200h
mov word ptr es:[7ch*4+2],0 ;設(shè)置中斷向量表
mov ax,4c00h
int 21h
do0:push bp
mov bp,spadd [bp+2],bx ;ok的偏移地址+bx得到s的偏移地址
pop bp
iret
mov ax,4c00h
int 21h
do0end:nop
code ends
end start
檢測(cè)點(diǎn)13.2
判斷下面說(shuō)法的正誤:
(1)我們可以編程改變FFFF:0處的指令,使得CPU不去執(zhí)行BIOS中的硬件系統(tǒng)檢測(cè)和初始化程序。答:錯(cuò)誤,FFFF:0處的內(nèi)容無(wú)法改變。檢測(cè)點(diǎn)13.2
判斷下面說(shuō)法的正誤:
(2)int 19h中斷例程,可以由DOS提供。答:錯(cuò)誤,先調(diào)用int 19h,后啟動(dòng)DOS。
檢測(cè)點(diǎn)14.1 讀取寫(xiě)入CMOS RAM單元內(nèi)容
(1)編程,讀取CMOS RAM的2號(hào)單元內(nèi)容。assume cs:code
code segment
start: mov al,2 ;賦值alout 70h,al ;將al送入端口70hin al,71h ;從端口71h處讀出單元內(nèi)容mov ax,4c00hint 21h
code ends
end start
檢測(cè)點(diǎn)14.1
(2)編程,向CMOS RAM的2號(hào)單元寫(xiě)入0。assume cs:code
code segment
start: mov al,2 ;賦值alout 70h,al ;將al送入端口70hmov al,0 ;賦值alout 71h,al ;向端口71h寫(xiě)入數(shù)據(jù)almov ax,4c00hint 21h
code ends
end start
編程,用加法和移位指令計(jì)算(ax)=(ax)*10
提示:(ax)*10=(ax)*2+(ax)*8assume cs:code
code segment
start: mov bx,axshl ax,1 ;左移1位(ax)=(ax)*2mov cl,3shl bx,cl ;左移3位(bx)=(ax)*8add ax,bx ;(ax)=(ax)*2+(ax)*8mov ax,4c00hint 21h
code ends
end start;應(yīng)用舉例:計(jì)算ffh*10
assume cs:code
code segment
start: mov ax,0ffhmov bx,axshl ax,1 ;左移1位(ax)=(ax)*2mov cl,3shl bx,cl ;左移3位(bx)=(ax)*8add ax,bx ;(ax)=(ax)*2+(ax)*8mov ax,4c00hint 21h
code ends
end startPS:
左移1位,N=(N)*2
左移2位,N=(N)*4
左移3位,N=(N)*8
左移4位,N=(N)*16
左移5位,N=(N)*32
總結(jié)
以上是生活随笔為你收集整理的汇编语言王爽第二版-课后答案以及解析的全部?jī)?nèi)容,希望文章能夠幫你解決所遇到的問(wèn)題。
- 上一篇: 【2016年第4期】分布式协商:建立稳固
- 下一篇: 汇编-寄存器