微機原理答案南京理工大學.doc
《微機原理答案南京理工大學.doc》由會員分享,可在線閱讀,更多相關《微機原理答案南京理工大學.doc(38頁珍藏版)》請在裝配圖網上搜索。
目錄 CH01 微型計算機概述 1 CH02 8086/8088 指令系統(tǒng) 6 CH03 匯編語言程序設計 12 CH04 存儲系統(tǒng) 27 CH05 定時與計數(shù) 31 CH06 輸入輸出控制 35 CH01 微型計算機概述 1. 微型計算機由哪些部件組成?各部件的主要功能是什么? 解答: 微機系統(tǒng) 微型計算機 系統(tǒng)軟件 外圍設備:打印機、鍵盤、CRT、磁盤控制器等 微處理器 (CPU) 系統(tǒng)總線:AB、CB、DB (功能:為CPU和其他部件之間提供數(shù)據(jù)、地址 和控制信息的傳輸通道) 存儲器:只讀存儲器(ROM)、隨機存儲器(RAM) (功能:用來存儲信息) 輸入/輸出(I/O)接口:串/并行接口等 (功能:使外部設備和微型機相連) 算術邏輯部件(ALU) 累加器、寄存器 控制器 操作系統(tǒng)(OS) 系統(tǒng)實用程序:匯編、編譯、編輯、調試程序等 (注:CPU的功能--①可以進行算術和邏輯運算; ②可保存少量數(shù)據(jù); ③能對指令進行譯碼并執(zhí)行規(guī)定的動作; ④能和存儲器、外設交換數(shù)據(jù); ⑤提供整修系統(tǒng)所需要的定時和控制; ⑥可以響應其他部件發(fā)來的中斷請示。) 2. 8086/8088 CPU 由哪兩部分組成?它們的主要功能各是什么?是如何協(xié)調工作的? 解答: 微處理器(CPU): 總線接口部件(BIU):負責與存儲器、I/O端口傳送數(shù)據(jù) 執(zhí)行部件(EU):負責指令的執(zhí)行 協(xié)調工作過程: 總線接口部件和執(zhí)行部件并不是同步工作的,它們按以下流水線技術原則來協(xié)調管理: ① 每當8086 的指令隊列中有兩個空字節(jié),或者8088 的指令隊列中有一個空字節(jié)時,總線接口部件就會自動把指令取到指令隊列中。 ② 每當執(zhí)行部件準備執(zhí)行一條指令時,它會從總線接口部件的指令隊列前部取出指令 的代碼,然后用幾個時鐘周期去執(zhí)行指令。在執(zhí)行指令的過程中,如果必須訪問存儲器或者 輸入/輸出設備,那么,執(zhí)行部件就會請求總線接口部件進入總線周期,完成訪問內存或者 輸入/輸出端口的操作;如果此時總線接口部件正好處于空閑狀態(tài),那么,會立即響應執(zhí)行 部件的總線請求。但有時會遇到這樣的情況,執(zhí)行部件請求總線接口部件訪問總線時,總線 接口部件正在將某個指令字節(jié)取到指令隊列中,此時總線接口部件將首先完成這個取指令的 操作,然后再去響應執(zhí)行部件發(fā)出的訪問總線的請求。 ③ 當指令隊列已滿,而且執(zhí)行部件又沒有總線訪問請求時,總線接口部件便進入空閑狀態(tài)。④ 在執(zhí)行轉移指令、調用指令和返回指令時,由于程序執(zhí)行的順序發(fā)生了改變,不再是順序執(zhí)行下面一條指令,這時,指令隊列中已經按順序裝入的字節(jié)就沒用了。遇到這種情況,指令隊列中的原有內容將被自動消除,總線接口部件會按轉移位置往指令隊列裝入另一個程序段中的指令。 3. 8086/8088 CPU 中有哪些寄存器?各有什么用途?標志寄存器F 有哪些標志位?各在什么情況下置位? 解答: 寄存器功能 數(shù)據(jù)寄存器 AX 字乘法,字除法,字I/O BX 查表轉換 CX 串操作,循環(huán)次數(shù) DX 字節(jié)相乘,字節(jié)相除,間接I/O 變址寄存器 SI 源變址寄存器,用于指令的變址尋址 DI 目的變址寄存器,用于指令的變址尋址 指針寄存器 SP 堆棧指針寄存器,與SS 一起來確定堆棧在內存中的位置 BP 基數(shù)指針寄存器,用于存放基地址,以使8086/8088 尋址更加靈活 控制寄存器 IP 控制CPU 的指令執(zhí)行順序 PSW 用來存放8086/8088CPU 在工作過程中的狀態(tài) 段寄存器CS 控制程序區(qū) DS 控制數(shù)據(jù)區(qū) SS 控制堆棧區(qū) ES 控制數(shù)據(jù)區(qū) 標志寄存器F 的標志位:①控制標志: DF、IF、TF;②狀態(tài)標志:SF、ZF、AF、 PF、CF、OF。 標志寄存器F 的各標志位置位情況: CF:進位標志位。做加法時出現(xiàn)進位或做減法時出現(xiàn)借位,該標志位置1;否則清0。 PF:奇偶標志位。當結果的低8位中l(wèi) 的個數(shù)為偶數(shù)時,該標志位置1;否則清0。 AF:半進位標志位。在加法時,當位3 需向位4 進位,或在減法時位3 需向位4 借位 時,該標志位就置1;否則清0。該標志位通常用于對BCD 算術運算結果的調整。 ZF:零標志位。運算結果各位都為0 時,該標志位置1,否則清0。 SF:符號標志位。當運算結果的最高位為1 時,該標志位置1,否則清0。 TF:陷阱標志位(單步標志位)。當該位置1 時,將使8086/8088 進入單步指令工作方式。 在每條指令開始執(zhí)行以前,CPU 總是先測試TF 位是否為1,如果為1,則在本指令執(zhí) 行后將產生陷阱中斷,從而執(zhí)行陷阱中斷處理程序。該程序的首地址由內存的 00004H~00007H 4 個單元提供。該標志通常用于程序的調試。例如,在系統(tǒng)調試軟件 DEBUG 中的T 命令,就是利用它來進行程序的單步跟蹤的。 IF:中斷允許標志位。如果該位置1,則處理器可以響應可屏蔽中斷,否則就不能響應 可屏蔽中斷。 DF:方向標志位。當該位置1 時,串操作指令為自動減量指令,即從高地址到低地址 處理字符串;否則串操作指令為自動增量指令。 OF:溢出標志位。在算術運算中,帶符號的數(shù)的運算結果超出了8 位或16 位帶符號數(shù) 所能表達的范圍時,即字節(jié)運算大于十127 或小于-128 時,字運算大于十32767 或小于-32768 時,該標志位置位。 4.8086/8088系統(tǒng)中存儲器的邏輯地址和物理地址之間有什么關系?表示的范圍各為多少? 解答: 邏輯地址:段地址:偏移地址 物理地址:也稱為絕對地址,由段基址和偏移量兩部分構成。物理地址與系統(tǒng)中的存儲 空間是一一對應的。 邏輯地址與物理地址兩者之間的關系為:物理地址=段地址16+偏移地址 每個邏輯段的地址范圍:0000:0000H~FFFFH;0001:0000H~FFFFH;…;FFFF: 0000H~FFFFH;共有232個地址,但其中有許多地址是重疊的(體現(xiàn)出邏輯地址的優(yōu)勢, 可根據(jù)需要方便地寫出邏輯地址,又不影響其準確的物理地址,邏輯地址與物理地址的關系 為多對一的關系)。物理地址的地址范圍:00000H~FFFFFH。 5. 已知當前數(shù)據(jù)段位于存儲器的A1000H 到B0FFFH 范圍內,問DS=? 解答: A1000H→A100:0000 以A100H 為段地址的64K 物理地址的范圍是:偏移地址為 0000H~FFFFH,即A100:0000H~A100:FFFFH→A1000H+0000H~A1000H+0FFFFH =A1000H~B0FFFH,∴DS=A100H。 6. 某程序數(shù)據(jù)段中存有兩個字數(shù)據(jù)1234H 和5A6BH,若已知DS=5AA0H,它們的偏移地址分別為245AH 和3245H,試畫出它們在存儲器中的存放情況 解答: 存放情況如圖所示(左右兩側的寫法均可): 5AA0: 0000H 5AA0: 245AH 5AA0: 245BH 5AA0: 3245H 5AA0: 3246H 34H 12H 6BH 5AH 5AA00H 5CE5AH 5CE5BH 5DC45H 5DC46H 7. 8086/8088CPU 有哪兩種工作模式,它們各有什么特點? 解答:為了適應各種不同的應用場合,8086/8088CPU 芯片可工作在兩種不同的工作模式下, 即最小模式與最大模式。 所謂最小模式,就是系統(tǒng)中只有一個8086/8088 微處理器,在這種情況下,所有的總 線控制信號,都是直接由這片8086/8088CPU 產生的,系統(tǒng)中的總線控制邏輯電路被減到最 少。該模式適用于規(guī)模較小的微機應用系統(tǒng)。 最大模式是相對于最小模式而言的,最大模式用在中、大規(guī)模的微機應用系統(tǒng)中。在最 大模式下,系統(tǒng)中至少包含兩個微處理器,其中一個為主處理器,即8086/8088CPU,其它 的微處理器稱之為協(xié)處理器,它們是協(xié)助主處理器工作的。 8. 若8086CPU 工作于最小模式,試指出當CPU 完成將AH 的內容送到物理地址為91001H 的存儲單元操作時,以下哪些信號應為低電平:M/ IO、RD 、WR 、BHE /S7、DT/ R 。若CPU 完成的是將物理地址91000H 單元的內容送到AL 中,則上述哪些信號應為低電平。若CPU 為8088 呢? 解答:8086CPU ①存儲器寫(AH→9100H[0001H])時為低電平的信號:WR、BHE /S7 。 ②存儲器讀(9100H[0000H]→AL)時為低電平的信號:RD 、DT/ R 。 8088CPU ①存儲器寫(AH→9100H[0001H])時為低電平的信號:WR、BHE /S7 、M/ IO。 ②存儲器讀(9100H[0000H]→AL)時為低電平的信號:M/ IO、RD 、DT/ R 。 9. 什么是指令周期?什么是總線周期?什么是時鐘周期?它們之間的關系如何? 解答:指令周期----CPU 執(zhí)行一條指令所需要的時間稱為一個指令周期(Instruction Cycle)。 總線周期----每當CPU 要從存儲器或I/O 端口存取一個字節(jié)稱為一次總線操作,相應 于某個總線操作的時間即為一個總線周期(BUS Cycle)。 時鐘周期----時鐘周期是CPU 處理動作的最小時間單位,其值等于系統(tǒng)時鐘頻率的倒 數(shù),時鐘周期又稱為T 狀態(tài)。 它們之間的關系:若干個總線周期構成一個指令周期,一個基本的總線周期由4 個T組 成,我們分別稱為T1~T4,在每個T狀態(tài)下,CPU完成不同的動作。 10. 8086/8088 CPU 有哪些基本操作?基本的讀/寫總線周期各包含多少個時鐘周期? 什么情況下需要插入Tw 周期?應插入多少個Tw 取決于什么因素? 解答: ①8086/8088CPU最小模式下的典型時序有:存儲器讀寫;輸入輸出;中斷響應;系統(tǒng)復位及總線占用操作。 ②一個基本的CPU總線周期一般包含四個狀態(tài),即四個時鐘周期; ③在存儲器和外設速度較慢時,要在之后插入1個或幾個等待狀態(tài); ④應插入多少個取決于READY信號的狀態(tài),CPU沒有在狀態(tài)的一開始采樣到READY信號為低電平,就會在和之間插入等待狀態(tài),直到采樣到READY信號為高電平。 11. 試說明8086/8088 工作在最大和最小模式下系統(tǒng)基本配置的差異。8086/8088 微機 系統(tǒng)中為什么一定要有地址鎖存器?需要鎖存哪些信息? 解答:最大模式配置和最小模式配置有一個主要的差別:①就是在最大模式下,需要用外加 電路來對CPU 發(fā)出的控制信號進行變換和組合,以得到對存儲器和I/O 端口的讀/寫信號及對鎖存器(8282)和對總線收發(fā)器(8286)等等的控制信號。8288 總線控制器就是完成上面這些功能的專用芯片。②為多中斷源的需要,常采用中斷優(yōu)先權控制電路(如Intel8259A)。8086/8088 系統(tǒng)一定要有地址鎖存器――因為高四位地址和狀態(tài)信號是從同一組引腳上分時送出的,低16 位地址和數(shù)據(jù)是從同一組引腳上分時傳輸?shù)?,所以必須把地址信息鎖存起來。需要鎖存的信息:地址信號、BHE /S7 和IO/M (8086 為M/ IO)信號進行鎖存。 12.試簡述8086/8088 微機系統(tǒng)最小模式下從存器儲讀數(shù)據(jù)時的時序過程。 解答:正常的存儲器讀總線操作占用4 個時鐘周期,通常將它們稱為4 個T狀態(tài)即T1~ T4。 ① T1狀態(tài),IO/M=0,指出要訪問存儲器。送地址信號A19-0,地址鎖存信號ALE有效, 用來控制8282 鎖存地址。DT/ R =0,控制8286/8287 工作在接收狀態(tài)(讀)。 ② T2狀態(tài),A19~A16送狀態(tài)S6 ~S3,AD7 ~AD0浮空,準備接收數(shù)據(jù)。同時,RD =0,表 示要進行讀操作,而DEN =0 作為8286/8287 的選通信號,允許進行數(shù)據(jù)傳輸。 ③ T3狀態(tài),從指定的存儲單元將數(shù)據(jù)讀出送AD7 ~AD0。若存儲器速度較慢,不能及時 讀出數(shù)據(jù)的話,則通過READY引腳通知CPU,CPU在T3的前沿采樣READY,如果 READY=0,則在T3結束后自動插入1 個或幾個等待狀態(tài)TW,并在每個TW的前沿檢 測READY,等到READY變高后,就自動脫離TW進入T4。 ④ T4狀態(tài),CPU采樣數(shù)據(jù)線,獲得數(shù)據(jù)。RD 、DEN 等信號失效。 CH02 8086/8088 指令系統(tǒng) 1.假定DS=2000H,ES=2100H,SS=1500H,SI=00A0H,BX=0100H,BP=0010H,數(shù)據(jù)變量VAL 的偏移地址為0050H,請指出下列指令源操作數(shù)是什么尋址方式?源操作數(shù)在哪 里?如在存儲器中請寫出其物理地址是多少? (1)MOV AX,0ABH (2)MOV AX,[100H] (3)MOV AX,VAL (4)MOV BX,[SI] (5)MOV AL,VAL[BX] (6)MOV CL,[BX][SI] (7)MOV VAL[SI],BX (8)MOV [BP][SI],100 解答: (1)MOV AX,0ABH 尋址方式:立即尋址;源操作數(shù)在數(shù)據(jù)線上;物理地址:無 (2)MOV AX,[100H] 尋址方式:直接尋址;源操作數(shù)在存儲器中;物理地址:DS*16+100H= 2000H*16+100H=20100H (3)MOV AX,VAL 尋址方式:直接尋址;源操作數(shù)在存儲器中;物理地址:DS*16+VAL= 2000H*16+0050H=20050H (4)MOV BX,[SI] 尋址方式:寄存器間接尋址;源操作數(shù)在存儲器中;物理地址:DS*16+SI= 2000H*16+00A0H=200A0H (5)MOV AL,VAL[BX] 尋址方式:變址尋址;源操作數(shù)在存儲器中;物理地址:DS*16+VAL+BX= 2000H*16+0050H+0100 =20150H (6)MOV CL,[BX][SI] 尋址方式:基址加變址尋址;源操作數(shù)在存儲器中;物理地址:DS*16+BX+SI= 2000H*16+0100H+00A0H =201A0H (7)MOV VAL[SI],BX 尋址方式:寄存器尋址;源操作數(shù)在寄存器中;物理地址:無 (8)MOV [BP][SI],100 尋址方式:立即尋址;源操作數(shù)在;物理地址:無 2.設有關寄存器及存儲單元的內容如下: DS=2000H , BX=0100H , AX=1200H , SI=0002H , [20100H]=12H , [20101H]=34H , [20102H]=56H , [20103]=78H , [21200]=2AH , [21201H]=4CH , [21202H]=0B7H , [21203H]=65H。 試說明下列各條指令單獨執(zhí)行后相關寄存器或存儲單元的內容。 (1)MOV AX,1800H (2)MOV AX,BX (3)MOV BX,[1200H] (4)MOV DX,1100[BX] (5)MOV [BX][SI],AL (6)MOV AX,1100[BX][SI] 解答: 題號指令執(zhí)行結果 (1) MOV AX,1800H AX=1800H (2) MOV AX,BX AX=0100H (3) MOV BX,[1200H] BX=4C2AH (4) MOV DX,1100[BX] DX=4C2AH (5) MOV [BX][SI],AL [20102H]=00H (6) MOV AX,1100[BX][SI] AX=65B7H 3.假定BX=0E3H,變量VALUE=79H,確定下列指令執(zhí)行后的結果(操作數(shù)均為無符號數(shù)。 對3、6,寫出相應標志位的狀態(tài))。 (1)ADD VALUE,BX (2)AND BX,VALUE (3)CMP BX,VALUE (4)XOR BX,0FFH (5)DEC BX (6)TEST BX,01H 解答: 題號指令執(zhí)行結果 (1) ADD VALUE,BX BX=015CH (2) AND BX,VALUE BX=0061H (3) CMP BX,VALUE BX=00E3H(CF=ZF=OF=SF=0,AF=PF=1) (4) XOR BX,0FFH BX=001CH (5) DEC BX BX=00E2H (6) TEST BX,01H BX=00E3H(CF=ZF=OF=SF=AF=PF=0) 4.已知SS=0FFA0H,SP=00B0H,先執(zhí)行兩條把8057H 和0F79H 分別進棧的PUSH 指令,再執(zhí)行一條POP 指令,試畫出堆棧區(qū)和SP 內容變化的過程示意圖。(標出存儲單元的地 址) 解答: 00ADH 00AEH 00AFH 0FFA0: 00B0H FFAACH FFAADH FFAAEH FFAAFH FFAB0H 00ACH X FFAABH 00ADH 00AEH 00AFH 0FFA0: 00B0H 57H 80H FFAACH FFAADH FFAAEH FFAAFH FFAB0H 00ACH X FFAABH ①初始狀態(tài);SP= 00B0H ② PUSH AX; ( AX= 8057H) SP= 00AEH 00ADH 00AEH 00AFH 0FFA0: 00B0H 79H 0FH 57H 80H FFAACH FFAADH FFAAEH FFAAFH FFAB0H 00ACH X FFAABH 00ADH 00AEH 00AFH 0FFA0: 00B0H 57H 80H FFAACH FFAADH FFAAEH FFAAFH FFAB0H 00ACH X FFAABH ③ PUSH BX; ( BX= 0F79H) SP= 00ACH ④ POP BX; SP= 00AEH 堆棧段SS=0FFA0H 堆棧段SS=0FFA0H 堆棧段SS=0FFA0H 堆棧段SS=0FFA0H 5.已知程序段如下: MOV AX,1234H MOV CL,4 ROL AX,CL DEC AX MOV CX,4 MUL CX 試問:(1)每條指令執(zhí)行后,AX 寄存器的內容是什么?(2)每條指令執(zhí)行后,CF,SF 及 ZF 的值分別是什么?(3)程序運行結束時,AX 及DX 寄存器的值為多少? 指令執(zhí)行結果 AX CF SF ZF MOV AX,1234H AX=1234H MOV CL,4 AX=1234H ROL AX,CL AX=2341H 1 0 0 DEC AX AX=2340H 1 0 0 MOV CX,4 AX=2340H 1 0 0 MUL CX AX=8D00H,DX=0000H 0 0 0 6.寫出實現(xiàn)下列計算的指令序列。(假定X、Y、Z、W、R 都為字變量) (1)Z=W+(Z+X) (2)Z=W-(X+6)-(R+9) (3)Z=(W*X)/(R+6) (4)Z=((W-X)/5*Y)*2 解答:(1)Z=W+(Z+X) 題號指令題號指令 (1) Z=W+(Z+X) (2) Z=W-(X+6)-(R+9) MOV AX,Z MOV DX,R MOV BX,X ADD DX,9 MOV CX,W MOV BX,X ADD BX ADD BX,6 ADC CX MOV AX,W MOV Z,AX SUB AX,BX SUB AX,DX MOV Z,AX (3) Z=(W*X)/(R+6) (4) Z=((W-X)/5*Y)*2 MOV DX,0 MOV AX,W MOV AX,W MOV BX,X MOV BX,X SUB AX,BX MUL BX MOV DX,0 PUSH AX MOV CL,5 MOV AX,R DIV CL ADD AX,6 MOV BX,Y MOV CX,AX MUL BX POP AX MOV CL,2 DIV CX MUL CL MOV Z,AX MOV Z,AX MOV Z+1,DX MOV Z+1,DX 7.假定DX=1100100110111001B,CL=3,CF=1,試確定下列各條指令單獨執(zhí)行后DX 的值。 (1)SHR DX,1 (2)SHL DL,1 (3)SAL DH,1 (4)SAR DX,CL (5)ROR DX,CL (6)ROL DL,CL (7)RCR DL,1 (8)RCL DX,CL 解答: 題號指令執(zhí)行結果 (1) SHR DX,1 DX=0110 0100 1101 1100(64DCH) (2) SHL DL,1 DX=1100 1001 0111 0010(C972H) (3) SAL DH,1 DX=1001 0010 1011 1001(92B9H) (4) SAR DX,CL DX=1111 1001 0011 0111(F937H) (5) ROR DX,CL DX=0011 1001 0011 0111(3937H) (6) ROL DL,CL DX=1100 1001 1100 1101(C9CDH) (7) RCR DL,1 DX=1100 1001 1101 1100(C9DCH) (8) RCL DX,CL DX=0100 1101 1100 1011(4DCFH) 8.已知DX=1234H,AX=5678H,試分析下列程序執(zhí)行后DX、AX 的值各是什么?該程序完成了什么功能? MOV CL,4 SHL DX,CL MOV BL,AH SHL BL,CL SHR BL,CL OR DL,BL 解答:DX=2345H,AX=6780H。該程序完成的功能如圖所示,將DX,AX拼裝成雙字后, 左移四位。 DX DX AX 1 2 3 4 5 6 7 8 DX AX 2 3 4 0 6 7 8 0 2 3 4 5 6 7 8 0 AX 9.試分析下列程序段: ADD AX,BX JNC L2 SUB AX,BX JNC L3 JMP SHORTL5 如果AX、BX 的內容給定如下: AX BX (1)14C6H 80DCH (2)B568H 54B7H 問該程序在上述情況下執(zhí)行后,程序轉向何處? 解答:(1)AX=AX+BX=14C6H+80DCH=95A2H;CF=0;無進位,轉移至L2; (2)AX=AX+BX=B568H+54B7H=0A1FH;CF=1;有進位,繼續(xù)執(zhí)行; AX=AX-BX=0A1FH+54B7H=B568H;CF=1;有借位,繼續(xù)執(zhí)行; 無條件轉移至SHORTL5 10.編寫一段程序,比較兩個5 字節(jié)的字符串OLDS 和NEWS,如果OLDS 字符串不同于NEWS 字符串,則執(zhí)行NEW_LESS,否則順序執(zhí)行。解答:編程如下,(說明:左測程序為常規(guī)編法,兩個字符串在一個數(shù)據(jù)段中;右測的程序要求OLDS在數(shù)據(jù)段中,NEWS在附加段中,利用串操作的指令是可行的) LEA SI,OLDS; LEA SI,OLDS LEA DI,NEWS; LEA DI,NEWS MOV CX,5; MOV CX,5 NEXT: MOV AL,[SI]; CLD MOV BL,[DI]; REPE CMPSB CMP AL,BL; JNZ NEW_LESS JNZ NEW_LESS; …… INC SI; JMP EXIT INC DI; NEW_LESS: LOOP NEXT; …… …… EXIT: …… JMP EXIT NEW_LESS: …… EXIT: …… 11.若在數(shù)據(jù)段中從字節(jié)變量TABLE 相應的單元開始存放了0~15 的平方值,試寫出包含 有XLAT 指令的指令序列查找N(0~15)的平方。(設N 的值存放在CL 中) 解答: MOV BX,OFFSET TABLE;LEA BX,TABLE MOV CL,N MOV AL,CL XLAT 12.有兩個雙字數(shù)據(jù)串分別存放在ASC1 和ASC2 中(低字放低地址),求它們的差,結果放在ASC3 中(低字放低地址)。 ASC1 DW 578,400 ASC2 DW 694,12 ASC3 DW ?,? 解答:編程如下, LEA SI,ASC1 LEA DI,ASC2 LEA BX,ASC3 MOV CX,2 CLC NEXT: MOV AX,[SI] MOV DX,[DI] SBB AX,DX MOV [BX],AX INC SI INC SI INC DI INC DI INC BX INC BX LOOP NEXT CH03 匯編語言程序設計 1.下列語句在存儲器中分別為變量分配多少字節(jié)空間?并畫出存儲空間的分配圖。 VAR1 DB 10,2 VAR2 DW 5 DUP(?),0 VAR3 DB ‘HOW ARE YOU?’,3 DUP(1,2) VAR4 DD -1,1,0 解答:字節(jié)空間----VAR1:2;VAR2:12;VAR3:20;VAR4:12。 存儲空間的分配圖: DS:0000 0A 02 00 00 00 00 00 00— 00 00 00 00 00 00 48 4F 0010 57 20 20 41 52 45 20 20— 59 4F 55 3F 01 02 01 02 0020 01 02 FF FF FF FF 01 00—— 00 00 00 00 00 00 2.假定VAR1 和VAR2 為字變量,LAB 為標號,試指出下列指令的錯誤之處。 (1)ADD VAR1,VAR2 (2)SUB AL,VAR1 (3)JMP LAB[CX] (4)JNZ VAR1 (5) MOV [1000H],100 (6)SHL AL, 4 解答:(1)兩個操作數(shù)中至少有一個為寄存器; (2)AL 為字節(jié),VAR1 為字變量,不匹配; (3)[]中不能用CX,LAB 為標號,非變量; (4)轉向地址應為標號,不能是變量; (5)目的操作數(shù)的類型不確定; (6)SHL 指令中,當所移位數(shù)超過1 時,必須用CL 或CX 來取代所移位數(shù)。 3.對于下面的符號定義,指出下列指令的錯誤。 A1 DB ? A2 DB 10 K1 EQU 1024 (1) MOV K1,AX (2)MOV A1,AX (3)CMP A1,A2 (4)K1 EQU 2048 解答:(1)K1 為常量,不能用MOV 指令賦值; (2)A1 為字節(jié),AX 為字變量,不匹配; (3)A1 未定義,無法做比較指令; (4)K1 重新賦值前,必須用PURGE 釋放。 4.數(shù)據(jù)定義語句如下所示: FIRST DB 90H,5FH,6EH,69H SECOND DB 5 DUP(?) THIRD DB 5 DUP(?) 自FIRST 單元開始存放的是一個四字節(jié)的十六進制數(shù)(低位字節(jié)在前),要求: 編一段程序將這個數(shù)左移兩位后存放到自SECOND 開始的單元,右移兩位后存放到自 THIRD 開始的單元。(注意保留移出部分) 解答: DATA SEGMENT FIRST DB 90H,5FH,6EH,69H SECOND DB 5 DUP(?) THIRD DB 5 DUP(?) DATA ENDS CODE SEGMENT ASSUME CS:CODE,DS:DATA START:MOV AX,DATA MOV DS,AX LEA SI,F(xiàn)IRST LEA DI,SECOND MOV CX,2 CLC ;左移2 位 MOV AX,[SI];AX=5F90H 為低十六位數(shù)據(jù) INC SI INC SI MOV DX,[SI];DX=696EH 為高十六位數(shù)據(jù) PUSH DX;保存原有的高十六位數(shù)據(jù) PUSH AX;保存原有的低十六位數(shù)據(jù) ROL DX,CL;將高位數(shù)據(jù)不帶進位循環(huán)左移兩位,即高2 位數(shù)據(jù)在DL 的低2 位 AND DL,03H;讓DL 中僅保存移出的高2 位數(shù)據(jù) MOV [DI+4] ,DL;將移出的高2 位數(shù)據(jù)放入SECOND 中的最高單元中 ROL AX,CL;將低位數(shù)據(jù)不帶進位循環(huán)左移兩位,即AX 的高2 位在AL 的低2 位 AND AL,03H;讓AL 中僅保存移出的AX 高2 位數(shù)據(jù) MOV BL ,AL;將AL 中的數(shù)據(jù)放入BL 中保存 POP AX;彈出原有的低十六位數(shù)據(jù) POP DX;彈出原有的高十六位數(shù)據(jù) SHL DX,CL;將高位數(shù)據(jù)算術邏輯左移2 位 SHL AX,CL;將低位數(shù)據(jù)算術邏輯左移2 位 OR DL,BL;將AX 中移出的高2 位數(shù)據(jù)放入DX 的低2 位 MOV [DI] ,AX MOV [DI+2] ,DX ;右移2 位 LEA SI,F(xiàn)IRST LEA DI,THIRD MOV CX,2 CLC MOV AX,[SI];AX=5F90H 為低十六位數(shù)據(jù) INC SI INC SI MOV DX,[SI];DX=696EH 為高十六位數(shù)據(jù) PUSH DX;保存原有的高十六位數(shù)據(jù)PUSH AX;保存原有的低十六位數(shù)據(jù) ROR AX,CL;將低位數(shù)據(jù)不帶進位循環(huán)右移兩位,即低2 位數(shù)據(jù)在AH 的高2 位 AND AH,0C0H;讓AH 中僅保存移出的低2 位數(shù)據(jù) PUSH CX MOV CX,6 SHR AH,CL POP CX MOV [DI] ,AH;將移出的低2 位數(shù)據(jù)放入THIRD 中的最低單元中 ROR DX,CL;將低位數(shù)據(jù)不帶進位循環(huán)左移兩位,即AX 的高2 位在AL 的低2 位 AND DH,0C0H;讓DH 中僅保存移出的DX 低2 位數(shù)據(jù) MOV BL ,DH;將DH 中的數(shù)據(jù)放入BL 中保存 POP AX;彈出原有的低十六位數(shù)據(jù) POP DX;彈出原有的高十六位數(shù)據(jù) SHR DX,CL;將高位數(shù)據(jù)算術邏輯左移2 位 SHR AX,CL;將低位數(shù)據(jù)算術邏輯左移2 位 OR AH,BL;將DX 中移出的低2 位數(shù)據(jù)放入AX 的高2 位 MOV [DI+1] ,AX MOV [DI+3] ,DX MOV AH,4CH INT 21H CODE ENDS END START 5.(14)在當前數(shù)據(jù)區(qū)從400H 開始的256 個單元中存放著一組數(shù)據(jù),試編程序將它們順序搬移到從A000H 開始的順序256 個單元中。 解答: DATA SEGMENT ORG 400H DAT1 DB ...;256 DUP (?) ORG 0A000H DAT2 DB ...;256 DUP (?) DATA ENDS ; STACK SEGMENT STACK ENDS ; CODE SEGMENT ASSUME DS:DATA,CS:CODE,SS:STACK,ES:DATA START: MOV AX,DATA MOV DS,AX ;CH3-14 LEA SI,DAT1 LEA DI,DAT2 MOV CX,128 AGAIN: MOV AL,[SI] MOV [DI],AL INC SI INC DI LOOP AGAIN ;CH3-15,將兩個數(shù)據(jù)塊逐個單元進行比較,若有錯BL=00H,否則BL=FFH LEA SI,DAT1 LEA DI,DAT2 MOV CX,128 NEXT: MOV AL,[SI] MOV BL,[DI] CMP AL,BL JNZ ERROR INC SI INC DI LOOP NEXT MOV BL,0FFH JMP EXIT ERROR: MOV BL,00H EXIT: MOV AX,4C00H INT 21H CODE ENDS END START 6.試編程序將當前數(shù)據(jù)區(qū)從BUFF 開始的4K 個單元中均寫入55H,并逐個單元讀出比較看寫入的與讀出的是否一致。若全對,則將ERR 單元置0H;如果有錯,則將ERR 單元 置FFH。 解答: DATA SEGMENT BUFF DB 1000H DUP(?) ERR DB ? DATA ENDS ; CODE SEGMENT ASSUME CS:CODE,DS:DATA START: MOV AX,DATA MOV DS,AX ;將55H 依次放入BUFF 開始的4K 個單元 LEA SI,BUFF MOV CX,1000H MOV AL,55H NTXT: MOV [SI],AL INC SI LOOP NEXT ;取出與55H 比較,全對則ERR=0,否則ERR=FFH LEA DI,BUFF LEA SI,ERR MOV CX,1000H NEXT1: MOV AL,[DI] INC DI CMP AL,55H JNZ ERROR;若有一個不同,即置ERR=FFH LOOP NEXT1 MOV AL,00H MOV [SI],AL;全比較完無錯,則置ERR=0 JMP EXIT ERROR: MOV AL,0FFH MOV [SI],AL ;返回DOS EXIT: MOV AH,4CH INT 21H CODE ENDS END START END 7.在上題中,如果發(fā)現(xiàn)有錯時,要求在ERR 單元中存放出錯的數(shù)據(jù)個數(shù),則程序該如何修改? 解答: DATA SEGMENT BUFF DB 1000H DUP(?) ERR DW ? DATA ENDS ; CODE SEGMENT ASSUME CS:CODE,DS:DATA START: MOV AX,DATA MOV DS,AX ;將55H 依次放入BUFF 開始的4K 個單元 LEA SI,BUFF MOV CX,1000H MOV AL,55H NTXT: MOV [SI],AL INC SI LOOP NEXT ;取出與55H 比較LEA DI,BUFF LEA SI,ERR MOV DX,0000H MOV CX,1000H NEXT1: MOV AL,[DI] INC DI CMP AL,55H JZ NEXT2;若相同,則比較下一個 INC DX;否則將放出錯個數(shù)的DX 加1 NEXT2: LOOP NEXT1 MOV [SI],DX ; EXIT: MOV AH,4CH INT 21H CODE ENDS END START END 8.試編寫程序段,完成將數(shù)據(jù)區(qū)從0100H 開始的一串字節(jié)數(shù)據(jù)逐個從F0H 端口輸出,已知數(shù)據(jù)串以0AH 為結束符。 解答: DATA SEGMENT ORG 0100H DATA1 DB N DUP(?) DATA ENDS ; CODE SEGMENT ASSUME CS:CODE,DS:DATA START: MOV AX,DATA MOV DS,AX ;將DATA1 數(shù)據(jù)串中的數(shù)據(jù)取出并從F0H 端口中輸出 LEA SI,DATA1 MOV CX,N MOV BL,0AH NTXT: MOV AL,[SI] CMP AL,BL JZ EXIT OUT 0F0H,AL INC SI LOOP NEXT ;返回DOS EXIT: MOV AH,4CH INT 21H CODE ENDS END START END 9.(24)內存中以FIRST 和SECOND 開始的單元中分別存放著兩個4 位用壓縮BCD 碼表示的十進制數(shù), 低位在前。編程序求這兩個數(shù)的和,仍用壓縮BCD 碼表示, 并存到以THIRD開始的單元。 解答: DATA SEGMENT FIRST DW 3412H SECOND DW 7856H THIRD DB ?,?,? DATA ENDS ; STACK SEGMENT STACK ENDS ; CODE SEGMENT ASSUME DS:DATA,CS:CODE,SS:STACK,ES:DATA START: MOV AX,DATA MOV DS,AX LEA SI,FIRST LEA DI,SECOND LEA BX,THIRD MOV CX,2 CLC AGAIN: MOV AL,BYTE PTR[SI] MOV DL,BYTE PTR[DI] ADC AL,DL DAA MOV BYTE PTR[BX],AL INC SI INC DI INC BX LOOP AGAIN JC AA MOV BYTE PTR[BX],0 JMP EXIT AA: MOV BYTE PTR[BX],1 EXIT: MOV AX,4C00H INT 21H CODE ENDS END START 10.(27)設字變量單元A、B、C 存放有三個數(shù),若三個數(shù)都不為零,則求三個數(shù)的和,存 放在D 中;若有一個為零,則將其余兩個也清零,試編寫程序。 解答: DATA SEGMENT A DB ? B DB ? C DB ? D DW ? DATA ENDS ; STACK SEGMENT STACK ENDS ; CODE SEGMENT ASSUME DS:DATA,CS:CODE,SS:STACK,ES:DATA START: MOV AX,DATA MOV DS,AX LEA SI,A LEA DI,D MOV AL,[SI] CMP AL,00 JZ ZERO ADC DX,AL LEA SI,B MOV AL,[SI] CMP AL,00 JZ ZERO ADC DX,AL LEA SI,C MOV AL,[SI] CMP AL,00 JZ ZERO ADC DX,AL MOV [DI],DX JMP EXIT ZERO: MOV AL,0 MOV A,AL MOV B,AL MOV C,AL ; EXIT: MOV AX,4C00H INT 21H CODE ENDS END START 11.(16)試編程序,統(tǒng)計由TABLE 開始的128 個單元中所存放的字符“A”的個數(shù),并將結 果存放在DX 中。 解答: DATA SEGMENT TABLE DB X1,X2,...X128 DATA ENDS ; STACK SEGMENT STACK ENDS ; CODE SEGMENT ASSUME DS:DATA,CS:CODE,SS:STACK,ES:DATA START: MOV AX,DATA MOV DS,AX LEA SI,TABLE MOV DX,0 MOV CX,128 AGAIN: MOV AL,[SI] CMP AL,A JNZ NEXT INC DX NEXT: INC SI LOOP AGAIN MOV AX,4C00H INT 21H CODE ENDS END START 12.試編制一個匯編語言程序,求出首地址為DATA 的1000 個字數(shù)組中的最小偶數(shù),并把它存放于MIN 單元中。 解答: DATA SEGMENT ARRAY DW X1,X2,...X1000 ARRAY_EVEN DW 1000 DUP(?) MIN DW ? MAX DW ? DATA ENDS ; STACK SEGMENT STACK ENDS ; CODE SEGMENT ASSUME DS:DATA,CS:CODE,SS:STACK,ES:DATA START: MOV AX,DATA MOV DS,AX ;將數(shù)組中的偶數(shù)放入ARRAY_EVEN 中 LEA SI,ARRAY LEA DI,ARRAY_EVEN MOV CX,1000 AGAIN: MOV AX,[SI] TEST AX,01h JNZ NEXT MOV [DI],AX INC DI INC DI NEXT: INC SI INC SI LOOP AGAIN ;找出ARRAY_EVEN 中的最大數(shù) LEA SI,ARRAY_EVEN MOV CX,999 MOV AX,[SI] MOV BX,AX INC SI INC SI NEXT: CMP AX,[SI] JAE LL MOV AX,[SI] LL: INC SI INC SI LOOP NEXT MOV MAX,AX ;找出ARRAY_EVEN 中的最小數(shù)(第13 題增加的部分) LEA SI,ARRAY_EVEN MOV CX,999 MOV AX,[SI] MOV BX,AX INC SI INC SI NEXT: CMP AX,[SI] JBE SS MOV AX,[SI] SS: INC SI INC SI LOOP NEXT MOV MIN,AX ;返回DOS MOV AX,4C00H INT 21H CODE ENDS END START 13.在上題中,如果要求同時找出最大和最小的偶數(shù),并把它們分別存放于MAX 和MIN 單元中,試完成程序。 解答:略(見第12 題)。 14.(28)在DATA 字數(shù)組中存放有100H 個16 位補碼數(shù),試編寫一程序求它們的平均值,放在AX 中,并求出數(shù)組中有多少個數(shù)小于平均值,將結果存于BX 中。 解答: DATA SEGMENT DAT DW X1,X2,...X256 DATA ENDS ; STACK SEGMENT STACK ENDS ; CODE SEGMENT ASSUME DS:DATA,CS:CODE,SS:STACK,ES:DATA START: MOV AX,DATA MOV DS,AX ;將數(shù)組中的100H 個數(shù)求和后求平均值 LEA SI,DAT MOV CX,100H CLC MOV BX,0000 MOV DX,0000 AGAIN: MOV AX,[SI] ADD BX,AX JNC NEXT ADC DX,1 NEXT: INC SI INC SI LOOP AGAIN MOV CX,100H MOV AX,BX DIV CX ;找出DAT 中的小于平均值的個數(shù) LEA SI,DAT MOV CX,100H MOV DX,0000H AGAIN0:MOV BX,[SI] CMP BX,AX;與平均值AX 比較,大于等于則轉NEXT0,否則將讀數(shù)器DX 加1 JGE NEXT0 INC DX NEXT0: INC SI INC SI LOOP AGAIN0 MOV BX,DX ;返回DOS MOV AX,4C00H INT 21H CODE ENDS END START 15.(17)編寫一個子程序,對AL 中的數(shù)據(jù)進行偶校驗,并將經過校驗的結果放回AL 中。 解答: DATA SEGMENT COUNT EQU 7 DATA ENDS ; STACK SEGMENT STACK ENDS ; CODE SEGMENT ASSUME DS:DATA,CS:CODE,SS:STACK,ES:DATA START: MOV AX,DATA MOV DS,AX PUSH AX MOV DX,0 MOV CX,COUNT AGAIN: RCR AL,1 JNC L INC DX L: LOOP AGAIN POP AX TEST DX,01 JZ EXIT OR AL,80 EXIT: MOV AX,4C00H INT 21H ;ANOTHER METHORD JP EXIT OR AL,80H EXIT: MOV AX,4C00H INT 21H CODE ENDS END START 16.(18)利用上題的予程序,對DATA 開始的256 個單元的數(shù)據(jù)加上偶校驗,試編程序。 解答: DATA SEGMENT DAT DB ...;256 DUP (?) RESULT DB ...;256 DUP (?) NUM EQU 256 COUNT EQU 7 DATA ENDS ; STACK SEGMENT STACK ENDS ; CODE SEGMENT ASSUME DS:DATA,CS:CODE,SS:STACK,ES:- 配套講稿:
如PPT文件的首頁顯示word圖標,表示該PPT已包含配套word講稿。雙擊word圖標可打開word文檔。
- 特殊限制:
部分文檔作品中含有的國旗、國徽等圖片,僅作為作品整體效果示例展示,禁止商用。設計者僅對作品中獨創(chuàng)性部分享有著作權。
- 關 鍵 詞:
- 微機 原理 答案 南京理工大學
裝配圖網所有資源均是用戶自行上傳分享,僅供網友學習交流,未經上傳用戶書面授權,請勿作他用。
鏈接地址:http://www.3dchina-expo.com/p-12744629.html