日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 编程资源 > 编程问答 >内容正文

编程问答

汇编语言王爽第二版-课后答案以及解析

發布時間:2025/3/15 编程问答 33 豆豆
生活随笔 收集整理的這篇文章主要介紹了 汇编语言王爽第二版-课后答案以及解析 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.
檢測點1.111個CPU的尋址能力為8KB,那么它的地址總線的寬度為 13位。 (21KB的存儲器有 1024 個存儲單元,存儲單元的編號從 01023 。 (31KB的存儲器可以存儲 81922^13) 個bit, 1024個Byte。 (41GB是 10737418242^30) 個Byte、1MB是 10485762^20) 個Byte、1KB是 10242^10)個Byte。 (5808080888029680386的地址總線寬度分別為16根、20根、24根、32根,則它們的尋址能力分別為: 64 (KB)、 1 (MB)、 16 (MB)、 4 (GB)。 (68080808880868028680386的數據總線寬度分別為8根、8根、16根、16根、32根。則它們一次可以傳送的數據為: 1 (B)、 1 (B)、 2 (B)、 2 (B)、 4 (B)。 (7)從內存中讀取1024字節的數據,8086至少要讀 512 次,80386至少要讀 256 次。 (8)在存儲器中,數據和程序以 二進制 形式存放。解題過程: (11KB=1024B,8KB=1024B*8=2^N,N=13。 (2)存儲器的容量是以字節為最小單位來計算的,1KB=1024B。 (38Bit=1Byte,1024Byte=1KB(1KB=1024B=1024B*8Bit)。 (41GB=1073741824B(即2^301MB=1048576B(即2^201KB=1024B(即2^10)。 (5)一個CPU有N根地址線,則可以說這個CPU的地址總線的寬度為N。這樣的CPU最多可以尋找2的N次方個內存單元。(一個內存單元=1Byte)。 (68根數據總線一次可以傳送8位二進制數據(即一個字節)。 (78086的數據總線寬度為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條指令,編程計算24次方。 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.21)補全下面的程序,使其可以將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.22)補全下面的程序,使其可以將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.11)下面的程序實現依次用內存0:0~0:15單元中的內容改寫程序中的數據,完成程序: 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 檢測點6.12)下面的程序實現依次用內存0:0~0:15單元中的內容改寫程序中的數據,數據的傳送用棧來進行。棧空間設置在程序內。完成程序: 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指令執行后,CS:IP指向程序的第一條指令,在data段中應該定義哪些數據?答案①db 3 dup (0) 答案②dw 2 dup (0) 答案③dd 0 jmp word ptr [bx+1]為段內轉移,要CS:IP指向程序的第一條指令,應設置ds:[bx+1]的字單元(2個字節)存放數據應為0,則(ip)=ds:[bx+1]=0 簡單來說就是,只要ds:[bx+1]起始地址的兩個字節為0就可以了檢測點9.11)程序如下。 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 補全程序,使用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 程序中的mov [bx],bx這條指令,是將ip設置為0 mov [bx+2],cs,將cs這個段地址放入內存單元 執行后,cs應該不變,只調整ip為0(ip)=ds:[0]=0 檢測點9.13)用Debug查看內存,結果如下: 2000:1000 BE 00 06 00 00 00 ...... 則此時,CPU執行指令: mov ax,2000h mov es,ax jmp dword ptr es:[1000h] 后,(cs)= 0006H ,(ip)= 00BEH解析: jmp dword ptr為段間轉移,高位存放段地址,低位存放偏移地址 (cs)=(內存單元地址+2)(ip)=(內存單元地址)根據書P16,對于寄存器AX,AH為高位(1字節為高位),AL為低位(1字節為低位) 推算出(內存單元地址)=00beh,(內存單元地址+2)=0006h 根據書P182,高位存放段地址(2個字節為高位),低位存放偏移地址(2個字節為低位) (cs)=(內存單元地址+2)(ip)=(內存單元地址) 推算出(cs)=0006h,(ip)=00beh 檢測點9.2 補全編程,利用jcxz指令,實現在內存2000H段中查找第一個值為0的字節,找到后,將它的偏移地址存儲在dx中。 assume cs:code code segmentstart: mov ax,2000hmov ds,axmov bx,0s: mov ch,0 mov cl,[bx]jcxz ok ;當cx=0時,CS:IP指向OKinc bx jmp short sok: mov dx,bxmov ax ,4c00hint 21h code ends end start 檢測點9.3 補全編程,利用loop指令,實現在內存2000H段中查找第一個值為0的字節,找到后,將它的偏移地址存儲在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書P101,執行loop s時,首先要將(cx)1。 “loop 標號”相當于 dec cx if((cx)0) jmp short 標號 檢測點10.1 補全程序,實現從內存10000000處開始執行指令。 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執行reft指令時,相當于進行: pop ip pop cs 根據棧先進后出原則,應先將段地址cs入棧,再將偏移地址ip入棧。檢測點10.2 下面的程序執行后,ax中的數值為多少? 內存地址 機器碼 匯編指令 執行后情況 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進行跟蹤確認,“call 標號”是將該指令后的第一個字節偏移地址入棧,再轉到標號處執行指令。assume cs:code code segment start: mov ax,0call sinc ax s: pop axmov ax,4c00hint 21h code ends end start檢測點10.3 下面的程序執行后,ax中的數值為多少? 內存地址 機器碼 匯編指令 執行后情況 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進行跟蹤確認,“call far ptr s”是先將該指令后的第一個字節段地址cs=1000h入棧,再將偏移地址ip=8h入棧,最后轉到標號處執行指令。 出棧時,根據棧先進后出的原則,先出的為ip=8h,后出的為cs=1000h 檢測點10.4 下面的程序執行后,ax中的數值為多少? 內存地址 機器碼 匯編指令 執行后情況 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進行跟蹤確認,“call ax(16位reg)”是先將該指令后的第一個字節偏移地址ip入棧,再轉到偏移地址為ax(16位reg)處執行指令。檢測點10.51)下面的程序執行后,ax中的數值為多少? 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推算: 執行call word ptr ds:[0eh]指令時,先cs入棧,再ip=11入棧,最后ip轉移到(ds:[0eh])(ds:[0eh])=11h,執行inc ax……最終ax=3題中特別關照別用debug跟蹤,跟蹤結果不一定正確,但還是忍不住去試試,看是什么結果。 根據單步跟蹤發現,執行call word ptr ds:[0eh]指令時,顯示ds:[0eh]065D。 ds:0000~ds:0010不是已設置成stack數據段了嘛,不是應該全都是0的嘛。 于是進行了更詳細的單步跟蹤,發現初始數據段中數據確實為0,但執行完mov ss,ax;mov sp,16這兩條指令后,數據段中數據發生改變。這是為什么呢?中斷唄~~~~ 檢測點10.52)下面的程序執行后,ax和bx中的數值為多少? 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入棧,轉到cs:1ah處執行指令;(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 檢測點11.1 寫出下面每條指令執行后,ZF、PF、SF、等標志位的值。 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檢測點涉及的相關內容: ZF是flag的第6位,零標志位,記錄指令執行后結果是否為0,結果為0時,ZF=1 PF是flag的第2位,奇偶標志位,記錄指令執行后結果二進制中1的個數是否為偶數,結果為偶數時,PF=1 SF是flag的第7位,符號標志位,記錄有符號運算結果是否為負數,結果為負數時,SF=1 add、sub、mul、div 、inc、or、and等運算指令影響標志寄存器 mov、push、pop等傳送指令對標志寄存器沒影響。檢測點11.2 寫出下面每條指令執行后,ZF、PF、SF、CF、OF等標志位的值。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檢測點涉及的相關內容: ZF是flag的第6位,零標志位,記錄指令執行后結果是否為0,結果為0時,ZF=1 PF是flag的第2位,奇偶標志位,記錄指令執行后結果二進制數中1的個數是否為偶數,結果為偶數時,PF=1 SF是flag的第7位,符號標志位,記錄有符號運算結果是否為負數,結果為負數時,SF=1 CF是flag的第0位,進位標志位,記錄無符號運算結果是否有進/借位,結果有進/借位時,SF=1 OF是flag的第11位,溢出標志位,記錄有符號運算結果是否溢出,結果溢出時,OF=1 add、sub、mul、div 、inc、or、and等運算指令影響flag mov、push、pop等傳送指令對flag沒影響檢測點11.3 (1)補全下面的程序,統計F000:032個字節中,大小在[32,128]的數據個數。mov ax,0f000hmov ds,axmov bx,0 ;ds:bx指向第一個字節mov dx,0 ;初始化累加器mov cx,32 s: mov al,[bx]cmp al,32 ;32進行比較jb s0 ;如果低于al轉到s0,繼續循環cmp al,128 ;128進行比較ja s0 ;如果高于al轉到s0,繼續循環inc dx s0: inc bxloop s[32,128]是閉區間,包括兩端點的值 (32,128)是開區間,不包括兩端點的值 檢測點11.3 (2)補全下面的程序,統計F000:032個字節中,大小在(32,128)的數據個數。mov ax,0f000hmov ds,axmov bx,0 ;ds:bx指向第一個字節mov dx,0 ;初始化累加器mov cx,32 s: mov al,[bx]cmp al,32 ;32進行比較jna s0 ;如果不高于al轉到s0,繼續循環cmp al,128 ;128進行比較jnb s0 ;如果不低于al轉到s0,繼續循環inc dx s0: inc bxloop s[32,128]是閉區間,包括兩端點的值 (32,128)是開區間,不包括兩端點的值檢測點11.4 下面指令執行后,(ax)= 45h mov ax,0 push ax popf mov ax,0fff0h add ax,0010h pushf pop ax and al,11000101B and ah,00001000B推算過程: popf后,標志寄存器中,本章節介紹的那些標志位都為0(但是此時標志寄存器并不是所有位置都為0,這個不用關心,沒學過的位置用*先代替),向下進行,那么pushf將計算后的當時狀態的標志寄存器入棧,然后pop給ax,這是ax是寄存器的值(這個值中包含了我們的*號),接下來就是對那些沒有學過的標志位的屏蔽操作,這就是最后兩條指令的意義所在,將不確定的位置都歸0,那么只剩下我們能夠確定的位置了,所以,結果就可以推理出來了。 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檢測點12.1 (1)用debug查看內存,情況如下: 0000:0000 68 10 A7 00 8B 01 70 00-16 00 9D 03 8B 01 70 003號中斷源對應的中斷處理程序入口的偏移地址的內存單位的地址為: 0070:018b檢測點涉及相關內容: 一個表項存放一個中斷向量,也就是一個中斷處理程序的入口地址,這個入口地址包括段地址和偏移地址,一個表項占兩個字,高地址存放段地址,低地址存放偏移地址檢測點12.1 (2) 存儲N號中斷源對應的中斷處理程序入口的偏移地址的內存單元的地址為: 4N 存儲N號中斷源對應的中斷處理程序入口的段地址的內存單元的地址為: 4N+2檢測點涉及相關內容: 一個表項存放一個中斷向量,也就是一個中斷處理程序的入口地址,這個入口地址包括段地址和偏移地址,一個表項占兩個字,高地址存放段地址,低地址存放偏移地址 檢測點13.17ch中斷例程如下: lp: push bpmov bp,spdec cxjcxz lpretadd [bp+2],bx lpret: pop bpiret(1)在上面的內容中,我們用7ch中斷例程實現loop的功能,則上面的7ch中斷例程所能進行的最大轉移位移是多少?最大位移是FFFFH 檢測點13.1 (2)7ch中斷例程完成jmp near ptr s指令功能,用bx向中斷例程傳送轉移位移。應用舉例:在屏幕的第12行,顯示data段中以0結尾的字符串。 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位移,實現段內近轉移assume cs:code code segment start: mov ax,cs mov ds,ax mov si,offset do0 ;設置ds:si指向源地址 mov ax,0 mov es,ax mov di,200h ;設置es:di指向目標地址 mov cx,offset do0end-offset do0 ;設置cx為傳輸長度 cld ;設置傳輸方向為正 rep movsb mov ax,0 mov es,ax mov word ptr es:[7ch*4],200h mov word ptr es:[7ch*4+2],0 ;設置中斷向量表 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 檢測點13.2 判斷下面說法的正誤: (1)我們可以編程改變FFFF:0處的指令,使得CPU不去執行BIOS中的硬件系統檢測和初始化程序。答:錯誤,FFFF:0處的內容無法改變。檢測點13.2 判斷下面說法的正誤: (2)int 19h中斷例程,可以由DOS提供。答:錯誤,先調用int 19h,后啟動DOS。 檢測點14.1 讀取寫入CMOS RAM單元內容 (1)編程,讀取CMOS RAM的2號單元內容。assume cs:code code segment start: mov al,2 ;賦值alout 70h,al ;將al送入端口70hin al,71h ;從端口71h處讀出單元內容mov ax,4c00hint 21h code ends end start 檢測點14.12)編程,向CMOS RAM的2號單元寫入0。assume cs:code code segment start: mov al,2 ;賦值alout 70h,al ;將al送入端口70hmov al,0 ;賦值alout 71h,al ;向端口71h寫入數據almov ax,4c00hint 21h code ends end start 編程,用加法和移位指令計算(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;應用舉例:計算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

總結

以上是生活随笔為你收集整理的汇编语言王爽第二版-课后答案以及解析的全部內容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。