微型計算機原理及應(yīng)用課后答案侯曉霞.doc
《微型計算機原理及應(yīng)用課后答案侯曉霞.doc》由會員分享,可在線閱讀,更多相關(guān)《微型計算機原理及應(yīng)用課后答案侯曉霞.doc(45頁珍藏版)》請在裝配圖網(wǎng)上搜索。
CH01微型計算機概述習(xí)題與思考題1 微型計算機由哪些部件組成?各部件的主要功能是什么?解答:2 8086/8088 CPU由哪兩部分組成?它們的主要功能各是什么?是如何協(xié)調(diào)工作的?解答:協(xié)調(diào)工作過程:總線接口部件和執(zhí)行部件并不是同步工作的,它們按以下流水線技術(shù)原則來協(xié)調(diào)管理: 每當8086的指令隊列中有兩個空字節(jié),或者8088的指令隊列中有一個空字節(jié)時,總線接口部件就會自動把指令取到指令隊列中。 每當執(zhí)行部件準備執(zhí)行一條指令時,它會從總線接口部件的指令隊列前部取出指令的代碼,然后用幾個時鐘周期去執(zhí)行指令。在執(zhí)行指令的過程中,如果必須訪問存儲器或者輸入/輸出設(shè)備,那么,執(zhí)行部件就會請求總線接口部件進入總線周期,完成訪問內(nèi)存或者輸入/輸出端口的操作;如果此時總線接口部件正好處于空閑狀態(tài),那么,會立即響應(yīng)執(zhí)行部件的總線請求。但有時會遇到這樣的情況,執(zhí)行部件請求總線接口部件訪問總線時,總線接口部件正在將某個指令字節(jié)取到指令隊列中,此時總線接口部件將首先完成這個取指令的操作,然后再去響應(yīng)執(zhí)行部件發(fā)出的訪問總線的請求。 當指令隊列已滿,而且執(zhí)行部件又沒有總線訪問請求時,總線接口部件便進入空閑狀態(tài)。 在執(zhí)行轉(zhuǎn)移指令、調(diào)用指令和返回指令時,由于程序執(zhí)行的順序發(fā)生了改變,不再是順序執(zhí)行下面一條指令,這時,指令隊列中已經(jīng)按順序裝入的字節(jié)就沒用了。遇到這種情況,指令隊列中的原有內(nèi)容將被自動消除,總線接口部件會按轉(zhuǎn)移位置往指令隊列裝入另一個程序段中的指令。3 8086/8088 CPU中有哪些寄存器?各有什么用途?標志寄存器F有哪些標志位?各在什么情況下置位?解答:寄存器功能數(shù)據(jù)寄存器AX字乘法,字除法,字I/OBX查表轉(zhuǎn)換CX串操作,循環(huán)次數(shù)DX字節(jié)相乘,字節(jié)相除,間接I/O變址寄存器SI源變址寄存器,用于指令的變址尋址DI目的變址寄存器,用于指令的變址尋址指針寄存器SP堆棧指針寄存器,與SS一起來確定堆棧在內(nèi)存中的位置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的標志位:控制標志:OF、DF、IF、TF;狀態(tài)標志:SF、ZF、AF、PF、CF。標志寄存器F的各標志位置位情況: CF:進位標志位。做加法時出現(xiàn)進位或做減法時出現(xiàn)借位,該標志位置1;否則清0。 PF:奇偶標志位。當結(jié)果的低8位中l(wèi)的個數(shù)為偶數(shù)時,該標志位置1;否則清0。 AF:半進位標志位。在加法時,當位3需向位4進位,或在減法時位3需向位4借位時,該標志位就置1;否則清0。該標志位通常用于對BCD算術(shù)運算結(jié)果的調(diào)整。 ZF:零標志位。運算結(jié)果各位都為0時,該標志位置1,否則清0。 SF:符號標志位。當運算結(jié)果的最高位為1時,該標志位置1,否則清0。 TF:陷阱標志位(單步標志位)。當該位置1時,將使8086/8088進入單步指令工作方式。在每條指令開始執(zhí)行以前,CPU總是先測試TF位是否為1,如果為1,則在本指令執(zhí)行后將產(chǎn)生陷阱中斷,從而執(zhí)行陷阱中斷處理程序。該程序的首地址由內(nèi)存的00004H00007H 4個單元提供。該標志通常用于程序的調(diào)試。例如,在系統(tǒng)調(diào)試軟件DEBUG中的T命令,就是利用它來進行程序的單步跟蹤的。 IF:中斷允許標志位。如果該位置1,則處理器可以響應(yīng)可屏蔽中斷,否則就不能響應(yīng)可屏蔽中斷。 DF:方向標志位。當該位置1時,串操作指令為自動減量指令,即從高地址到低地址處理字符串;否則串操作指令為自動增量指令。 OF:溢出標志位。在算術(shù)運算中,帶符號的數(shù)的運算結(jié)果超出了8位或16位帶符號數(shù)所能表達的范圍時,即字節(jié)運算大于十127或小于128時,字運算大于十32767或小于32768時,該標志位置位。4 8086/8088系統(tǒng)中存儲器的邏輯地址和物理地址之間有什么關(guān)系?表示的范圍各為多少?解答:邏輯地址:段地址:偏移地址物理地址:也稱為絕對地址,由段基址和偏移量兩部分構(gòu)成。物理地址與系統(tǒng)中的存儲空間是一一對應(yīng)的。邏輯地址與物理地址兩者之間的關(guān)系為:物理地址段地址16+偏移地址每個邏輯段的地址范圍:0000:0000HFFFFH;0001:0000HFFFFH;FFFF:0000HFFFFH;共有232個地址,但其中有許多地址是重疊的(體現(xiàn)出邏輯地址的優(yōu)勢,可根據(jù)需要方便地寫出邏輯地址,又不影響其準確的物理地址,邏輯地址與物理地址的關(guān)系為多對一的關(guān)系)。物理地址的地址范圍:00000HFFFFFH。5 已知當前數(shù)據(jù)段位于存儲器的A1000H到B0FFFH范圍內(nèi),問DS=?解答:A1000HA100:0000以A100H為段地址的64K物理地址的范圍是:偏移地址為0000HFFFFH,即A100:0000HA100:FFFFHA1000H0000HA1000H0FFFFHA1000HB0FFFH,DSA100H。6 某程序數(shù)據(jù)段中存有兩個字數(shù)據(jù)1234H和5A6BH,若已知DS=5AA0H,它們的偏移地址分別為245AH和3245H,試畫出它們在存儲器中的存放情況解答:存放情況如圖所示(左右兩側(cè)的寫法均可):7 8086/8088CPU有哪兩種工作模式,它們各有什么特點?解答:為了適應(yīng)各種不同的應(yīng)用場合,8086/8088CPU芯片可工作在兩種不同的工作模式下,即最小模式與最大模式。所謂最小模式,就是系統(tǒng)中只有一個8086/8088微處理器,在這種情況下,所有的總線控制信號,都是直接由這片8086/8088CPU產(chǎn)生的,系統(tǒng)中的總線控制邏輯電路被減到最少。該模式適用于規(guī)模較小的微機應(yīng)用系統(tǒng)。 最大模式是相對于最小模式而言的,最大模式用在中、大規(guī)模的微機應(yīng)用系統(tǒng)中。在最大模式下,系統(tǒng)中至少包含兩個微處理器,其中一個為主處理器,即8086/8088CPU,其它的微處理器稱之為協(xié)處理器,它們是協(xié)助主處理器工作的。8 若8086CPU工作于最小模式,試指出當CPU完成將AH的內(nèi)容送到物理地址為91001H的存儲單元操作時,以下哪些信號應(yīng)為低電平:M/、/S7、DT/。若CPU完成的是將物理地址91000H單元的內(nèi)容送到AL中,則上述哪些信號應(yīng)為低電平。若CPU為8088呢?(略)9 什么是指令周期?什么是總線周期?什么是時鐘周期?它們之間的關(guān)系如何?解答:指令周期-CPU執(zhí)行一條指令所需要的時間稱為一個指令周期(Instruction Cycle)。總線周期-每當CPU要從存儲器或I/O端口存取一個字節(jié)稱為一次總線操作,相應(yīng)于某個總線操作的時間即為一個總線周期(BUS Cycle)。時鐘周期-時鐘周期是CPU處理動作的最小時間單位,其值等于系統(tǒng)時鐘頻率的倒數(shù),時鐘周期又稱為T狀態(tài)。它們之間的關(guān)系:若干個總線周期構(gòu)成一個指令周期,一個基本的總線周期由4個T組成,我們分別稱為T1T4,在每個T狀態(tài)下,CPU完成不同的動作。10 8086/8088 CPU有哪些基本操作?基本的讀/寫總線周期各包含多少個時鐘周期?什么情況下需要插入Tw周期?應(yīng)插入多少個Tw取決于什么因素?解答:8086/8088CPU最小模式下的典型時序有:存儲器讀寫;輸入輸出;中斷響應(yīng);系統(tǒng)復(fù)位及總線占用操作。一個基本的CPU總線周期一般包含四個狀態(tài),即四個時鐘周期;在存儲器和外設(shè)速度較慢時,要在之后插入1個或幾個等待狀態(tài);應(yīng)插入多少個取決于READY信號的狀態(tài),CPU沒有在狀態(tài)的一開始采樣到READY信號為低電平,就會在和之間插入等待狀態(tài),直到采樣到READY信號為高電平。11 試說明8086/8088工作在最大和最小模式下系統(tǒng)基本配置的差異。8086/8088微機系統(tǒng)中為什么一定要有地址鎖存器?需要鎖存哪些信息?(略,見書)12試簡述8086/8088微機系統(tǒng)最小模式下從存器儲讀數(shù)據(jù)時的時序過程。(略,見書)CH02 80868088指令系統(tǒng)習(xí)題與思考題1假定DS=2000H,ES=2100H,SS=1500H,SI=00A0H,BX=0100H,BP=0010H,數(shù)據(jù)變量VAL的偏移地址為0050H,請指出下列指令源操作數(shù)是什么尋址方式?源操作數(shù)在哪里?如在存儲器中請寫出其物理地址是多少?(1)MOV AX,0ABH(2)MOVAX,100H(3)MOVAX,VAL(4)MOVBX,SI(5)MOVAL,VALBX(6)MOVCL,BXSI(7)MOVVALSI,BX(8)MOVBPSI,100解答:(1)MOVAX,0ABH尋址方式:立即尋址;物理地址:無(2)MOVAX,100H尋址方式:直接尋址;源操作數(shù)在存儲器中;物理地址:DS16+100H2000H*16+100H20100H(3)MOVAX,VAL尋址方式:直接尋址;源操作數(shù)在存儲器中;物理地址:DS16+VAL2000H*16+0050H20050H(4)MOVBX,SI尋址方式:寄存器間接尋址;源操作數(shù)在存儲器中;物理地址:DS16+SI2000H*16+00A0H200A0H(5)MOVAL,VALBX尋址方式:變址尋址;源操作數(shù)在存儲器中;物理地址:DS16+VAL+BX2000H*16+0050H+010020150H(6)MOVCL,BXSI尋址方式:基址加變址尋址;源操作數(shù)在存儲器中;物理地址:DS16+BX+SI2000H*16+0100H+00A0H201A0H(7)MOVVALSI,BX尋址方式:寄存器尋址;源操作數(shù)在寄存器中;物理地址:無(8)MOVBPSI,100尋址方式:立即尋址;物理地址:無2設(shè)有關(guān)寄存器及存儲單元的內(nèi)容如下: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í)行后相關(guān)寄存器或存儲單元的內(nèi)容。(1)MOVAX,1800H (2)MOVAX,BX(3)MOVBX,1200H (4)MOVDX,1100BX(5)MOVBXSI,AL (6)MOVAX,1100BXSI解答:題號指令執(zhí)行結(jié)果(1)MOVAX,1800HAX1800H(2)MOVAX,BXAX0100H(3)MOVBX,1200HBX4C2AH(4)MOVDX,1100BXDX4C2AH(5)MOVBXSI,AL20102H00H(6)MOVAX,1100BXSIAX65B7H3假定BX=0E3H,變量VALUE=79H,確定下列指令執(zhí)行后的結(jié)果(操作數(shù)均為無符號數(shù)。對3、6,寫出相應(yīng)標志位的狀態(tài))。(1)ADDVALUE,BX (2)ANDBX,VALUE(3)CMP BX,VALUE(4)XORBX,0FFH(5)DECBX (6)TESTBX,01H解答:題號指令執(zhí)行結(jié)果(1)ADDVALUE,BXBX015CH(2)ANDBX,VALUEBX0061H(3)CMPBX,VALUEBX00E3H(CF=ZF=OF=SF=0,AF=PF=1)(4)XORBX,0FFHBX001CH(5)DECBXBX00E2H(6)TESTBX,01HBX00E3H(CF=ZF=OF=SF=AF=PF=0)4已知SS=0FFA0H,SP=00B0H,先執(zhí)行兩條把8057H和0F79H分別進棧的PUSH指令,再執(zhí)行一條POP指令,試畫出堆棧區(qū)和SP內(nèi)容變化的過程示意圖。(標出存儲單元的地址)解答:5已知程序段如下:MOVAX,1234HMOVCL,4ROLAX,CLDECAXMOVCX,4MULCX試問:(1)每條指令執(zhí)行后,AX寄存器的內(nèi)容是什么?(2)每條指令執(zhí)行后,CF,SF及ZF的值分別是什么?(3)程序運行結(jié)束時,AX及DX寄存器的值為多少?指令執(zhí)行結(jié)果AXCFSFZFMOVAX,1234HAX1234HMOVCL,4AX1234HROLAX,CLAX2341H100DECAXAX2340H100MOVCX,4AX2340H100MULCXAX8D00H,DX=0000H0006寫出實現(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)MOVAX,ZMOVDX,RMOVBX,XADDDX,9MOVCX,WMOVBX,XADDBXADDBX,6ADCCXMOVAX,WMOVZ,AXSUBAX,BXSUBAX,DXMOVZ,AX(3)Z=(W*X)/(R+6)(4)Z=(W-X)/5*Y)*2MOVDX,0MOVAX,WMOVAX,WMOVBX,XMOVBX,XSUBAX,BXMULBXMOVDX,0PUSHAXMOVCL,5MOVAX,RDIVCLADDAX,6MOVBX,YMOVCX,AXMULBXPOPAXMOVCL,2DIVCXMULCLMOVZ,AXMOVZ,AXMOVZ+1,DXMOVZ+1,DX7假定DX=1100100110111001B,CL=3,CF=1,試確定下列各條指令單獨執(zhí)行后DX的值。(1)SHRDX,1(2)SHLDL,1(3)SALDH,1(4)SARDX,CL(5)RORDX,CL(6)ROLDL,CL(7)RCRDL,1(8)RCLDX,CL解答:題號指令執(zhí)行結(jié)果(1)SHRDX,1DX=0110 0100 1101 1100(64DCH)(2)SHLDL,1DX=1100 1001 0111 0010(C972H)(3)SALDH,1DX=1001 0010 1011 1001(92B9H)(4)SARDX,CLDX=1111 1001 0011 0111(F937H)(5)RORDX,CLDX=0011 1001 0011 0111(3937H)(6)ROLDL,CLDX=1100 1001 1100 1101(C9CDH)(7)RCRDL,1DX=1100 1001 1101 1100(C9DCH)(8)RCLDX,CLDX=0100 1101 1100 1011(4DCFH)8已知DX=1234H,AX=5678H,試分析下列程序執(zhí)行后DX、AX的值各是什么?該程序完成了什么功能? MOVCL,4 SHLDX,CL MOVBL,AH SHLBL,CL SHRBL,CL ORDL,BL解答:DX=2345H,AX=6780H。該程序完成的功能如圖所示,將DX,AX拼裝成雙字后,左移四位。9試分析下列程序段:ADDAX,BXJNCL2SUBAX,BXJNCL3JMPSHORTL5如果AX、BX的內(nèi)容給定如下: AX BX(1)14C6H80DCH(2)B568H54B7H問該程序在上述情況下執(zhí)行后,程序轉(zhuǎn)向何處?解答:(1)AXAX+BX14C6H+80DCH95A2H;CF0;無進位,轉(zhuǎn)移至L2;(2)方法同(1),略10編寫一段程序,比較兩個5字節(jié)的字符串OLDS和NEWS,如果OLDS字符串不同于NEWS字符串,則執(zhí)行NEW_LESS,否則順序執(zhí)行。解答:編程如下,(說明:左測程序為常規(guī)編法,兩個字符串在一個數(shù)據(jù)段中;右測的程序要求OLDS在數(shù)據(jù)段中,NEWS在附加段中,利用串操作的指令是可行的)LEA SI,OLDS; LEA SI,OLDSLEA DI,NEWS; LEA DI,NEWSMOV CX,5; MOV CX,5NEXT:MOV AL,SI; CLDMOV BL,DI; REPE CMPSBCMP AL,BL; JNZ NEW_LESSJNZ NEW_LESS; INC SI; JMP EXITINC DI; NEW_LESS:LOOP NEXT; EXIT: JMP EXITNEW_LESS:EXIT:11若在數(shù)據(jù)段中從字節(jié)變量TABLE相應(yīng)的單元開始存放了015的平方值,試寫出包含有XLAT指令的指令序列查找N(015)的平方。(設(shè)N的值存放在CL中)解答:MOV BX,OFFSET TABLE;LEA BX,TABLEMOV CL,NMOV AL,CLXLAT12有兩個雙字數(shù)據(jù)串分別存放在ASC1和ASC2中(低字放低地址),求它們的差,結(jié)果放在ASC3中(低字放低地址)。ASC1 DW 578,400ASC2DW694,12ASC3DW?,?解答:編程如下,LEA SI,ASC1LEA DI,ASC2LEA BX,ASC3MOV CX,2CLCNEXT:MOV AX,SIMOV DX,DISBB AX,DXMOV BX,AXINC SIINC SIINC DIINC DIINC BXINC BXLOOP NEXTCH03 匯編語言程序設(shè)計習(xí)題與思考題1下列語句在存儲器中分別為變量分配多少字節(jié)空間?并畫出存儲空間的分配圖。VAR1 DB10,2VAR2DW5 DUP(?),0VAR3DBHOW ARE YOU?,$,3 DUP(1,2)VAR4DD-1,1,0解答:字節(jié)空間-VAR1:2;VAR2:12;VAR3:19;VAR4:12。存儲空間的分配圖:DS:0000 0A 02 00 00 00 00 00 0000 00 00 00 00 00 48 4F0010 57 20 41 52 45 20 59 4F55 3F 24 01 02 01 02 010020 02 FF FF FF FF 01 00 0000 00 00 00 002假定VAR1和VAR2為字變量,LAB為標號,試指出下列指令的錯誤之處。(1)ADDVAR1,VAR2(2)SUBAL,VAR1(3)JMPLABCX(4)JNZVAR1 (5) MOV 1000H,100 (6)SHL AL, 4 解答:(1)兩個操作數(shù)中至少有一個為寄存器;(2)AL為字節(jié),VAR1為字變量,不匹配;(3)中不能用CX;(4)轉(zhuǎn)向地址應(yīng)為標號;(5)目的操作數(shù)的類型不確定;(6)SHL指令中,當所移位數(shù)超過1時,必須用CL或CX來取代所移位數(shù)。3對于下面的符號定義,指出下列指令的錯誤。A1DB?A2DB10K1EQU1024(1)MOVK1,AX(2)MOVA1,AX(3)CMPA1,A2(4)K1EQU2048解答:(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é)在前),要求:編一段程序?qū)⑦@個數(shù)左移兩位后存放到自SECOND開始的單元,右移兩位后存放到自THIRD開始的單元。(注意保留移出部分)解答:DATA SEGMENTFIRST DB 90H,5FH,6EH,69H SECOND DB 5 DUP(?) THIRD DB 5 DUP(?) DATA ENDS CODE SEGMENTASSUME CS:CODE,DS:DATA START:MOV AX,DATAMOV DS,AXLEA SI,F(xiàn)IRSTLEA DI,SECONDMOV CX,2CLC;左移2位MOV AX,SIINC SIINC SIMOV DX,SIPUSH DX PUSH AXROL DX,CL AND DL,03H MOV DI+4,DL ROL AX,CL AND AL,03H MOV BL ,AL POP AX POP DX SHL DX,CLSHL AX,CLOR DL,BLMOV DI,AXMOV DI+2,DX;右移2位,類同左移的方法,略MOV AH,4CHINT 21H CODE ENDS END START5(原14)在當前數(shù)據(jù)區(qū)從400H開始的256個單元中存放著一組數(shù)據(jù),試編程序?qū)⑺鼈冺樞虬嵋频綇腁000H開始的順序256個單元中。解答:DATA SEGMENT ORG 400HDAT1 DB .;256 DUP (?) ORG 0A000HDAT2 DB .;256 DUP (?)DATA ENDSSTACK SEGMENTSTACK ENDSCODE SEGMENTASSUME DS:DATA,CS:CODE,SS:STACK,ES:DATASTART: MOV AX,DATA MOV DS,AX;CH3-14 LEA SI,DAT1 LEA DI,DAT2 MOV CX,128AGAIN: 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,128NEXT: MOV AL,SI MOV BL,DI CMP AL,BL JNZ ERROR INC SI INC DI LOOP NEXT MOV BL,0FFH JMP EXITERROR: MOV BL,00HEXIT: MOV AX,4C00H INT 21HCODE ENDSEND START6試編程序?qū)斍皵?shù)據(jù)區(qū)從BUFF開始的4K個單元中均寫入55H,并逐個單元讀出比較,看寫入的與讀出的是否一致。若全對,則將ERR單元置0H;如果有錯,則將ERR單元置FFH。解答:DATA SEGMENTBUFF DB 1000H DUP(?)ERR DB ?DATA ENDSCODE SEGMENT ASSUME CS:CODE,DS:DATASTART:MOV AX,DATAMOV DS,AX;將55H依次放入BUFF開始的4K個單元LEA SI,BUFFMOV CX,1000HMOV AL,55HNTXT:MOV SI,ALINC SILOOP NEXT;取出與55H比較,全對則ERR=0,否則ERR=FFHLEA DI,BUFFLEA SI,ERRMOV CX,1000HNEXT1:MOV AL,DIINC DICMP AL,55HJNZ ERROR;若有一個不同,即置ERR=FFHLOOP NEXT1MOV AL,00HMOV SI,AL;全比較完無錯,則置ERR=0JMP EXITERROR:MOV AL,0FFHMOV SI,AL;返回DOSEXIT:MOV AH,4CHINT 21HCODE ENDSEND STARTEND7在上題中,如果發(fā)現(xiàn)有錯時,要求在ERR單元中存放出錯的數(shù)據(jù)個數(shù),則程序該如何修改?解答:DATA SEGMENTBUFF DB 1000H DUP(?)ERR DW ?DATA ENDSCODE SEGMENT ASSUME CS:CODE,DS:DATASTART:MOV AX,DATAMOV DS,AX;將55H依次放入BUFF開始的4K個單元LEA SI,BUFFMOV CX,1000HMOV AL,55HNTXT:MOV SI,ALINC SILOOP NEXT;取出與55H比較LEA DI,BUFFLEA SI,ERRMOV DX,0000HMOV CX,1000HNEXT1:MOV AL,DIINC DICMP AL,55HJZ NEXT2;若相同,則比較下一個INC DX;否則將放出錯個數(shù)的DX加1NEXT2:LOOP NEXT1MOV SI,DXEXIT:MOV AH,4CHINT 21HCODE ENDSEND STARTEND8試編寫程序段,完成將數(shù)據(jù)區(qū)從0100H開始的一串字節(jié)數(shù)據(jù)逐個從F0H端口輸出,已知數(shù)據(jù)串以0AH為結(jié)束符。(略)9(原24)內(nèi)存中以FIRST和SECOND開始的單元中分別存放著兩個4位用壓縮BCD碼表示的十進制數(shù), 低位在前。編程序求這兩個數(shù)的和,仍用壓縮BCD碼表示, 并存到以THIRD開始的單元。解答:DATA SEGMENTFIRST DW 3412HSECOND DW 7856HTHIRD DB ?,?,?DATA ENDSSTACK SEGMENTSTACK ENDSCODE SEGMENTASSUME DS:DATA,CS:CODE,SS:STACK,ES:DATASTART: MOV AX,DATA MOV DS,AX LEA SI,FIRST LEA DI,SECOND LEA BX,THIRD MOV CX,2 CLCAGAIN: MOV AL,BYTE PTRSI MOV DL,BYTE PTRDI ADC AL,DL DAA MOV BYTE PTRBX,AL INC SI INC DI INC BX LOOP AGAIN JC AA MOV BYTE PTRBX,0 JMP EXITAA: MOV BYTE PTRBX,1EXIT: MOV AX,4C00H INT 21HCODE ENDSEND START10(原27)設(shè)字變量單元A、B、C存放有三個數(shù),若三個數(shù)都不為零,則求三個數(shù)的和,存放在D中;若有一個為零,則將其余兩個也清零,試編寫程序。解答:DATA SEGMENTA DB ?B DB ?C DB ?D DW ?DATA ENDSSTACK SEGMENTSTACK ENDSCODE SEGMENTASSUME DS:DATA,CS:CODE,SS:STACK,ES:DATASTART: MOV AX,DATA MOV DS,AXLEA SI,ALEA DI,DMOV AL,SICMP AL,00JZ ZEROADC DX,ALLEA SI,BMOV AL,SICMP AL,00JZ ZEROADC DX,ALLEA SI,CMOV AL,SICMP AL,00JZ ZEROADC DX,ALMOV DI,DXJMP EXITZERO:MOV AL,0MOV A,ALMOV B,ALMOV C,ALEXIT: MOV AX,4C00H INT 21HCODE ENDSEND START11(16)試編程序,統(tǒng)計由TABLE開始的128個單元中所存放的字符“A”的個數(shù),并將結(jié)果存放在DX中。解答:DATA SEGMENTTABLE DB X1,X2,.X128DATA ENDSSTACK SEGMENTSTACK ENDSCODE SEGMENTASSUME DS:DATA,CS:CODE,SS:STACK,ES:DATASTART: MOV AX,DATA MOV DS,AX LEA SI,TABLE MOV DX,0 MOV CX,128AGAIN: MOV AL,SI CMP AL,A JNZ NEXT INC DXNEXT: INC SI LOOP AGAIN MOV AX,4C00H INT 21HCODE ENDSEND START12試編制一個匯編語言程序,求出首地址為DATA的1000個字數(shù)組中的最小偶數(shù),并把它存放于MIN單元中。(方法:利用書上排序的例題做相應(yīng)的修改即可,略)13在上題中,如果要求同時找出最大和最小的偶數(shù),并把它們分別存放于MAX和MIN單元中,試完成程序。解答:略(方法同第12題)。14(28)在DATA字數(shù)組中存放有100H個16位補碼數(shù),試編寫一程序求它們的平均值,放在AX中,并求出數(shù)組中有多少個數(shù)小于平均值,將結(jié)果存于BX中。(略)15(17)編寫一個子程序,對AL中的數(shù)據(jù)進行偶校驗,并將經(jīng)過校驗的結(jié)果放回AL中。 解答:DATA SEGMENTCOUNT EQU 7DATA ENDSSTACK SEGMENTSTACK ENDSCODE SEGMENTASSUME DS:DATA,CS:CODE,SS:STACK,ES:DATASTART: MOV AX,DATA MOV DS,AX PUSH AX MOV DX,0 MOV CX,COUNTAGAIN: RCR AL,1 JNC L INC DXL: LOOP AGAIN POP AX TEST DX,01 JZ EXIT OR AL,80EXIT: MOV AX,4C00H INT 21H;ANOTHER METHORD JP EXIT OR AL,80HEXIT: MOV AX,4C00H INT 21HCODE ENDSEND START16(18)利用上題的予程序,對DATA開始的256個單元的數(shù)據(jù)加上偶校驗,試編程序。解答:DATA SEGMENTDAT DB .;256 DUP (?)RESULT DB .;256 DUP (?)NUM EQU 256COUNT EQU 7DATA ENDSSTACK SEGMENTSTACK ENDSCODE SEGMENTASSUME DS:DATA,CS:CODE,SS:STACK,ES:DATASTART: MOV AX,DATA MOV DS,AX LEA SI,DAT LEA DI,RESULT MOV CX,NUMNEXT: MOV AL,SI CALL SUB1 MOV DI,AL;MOV SI,AL INC SI INC DI LOOP NEXT MOV AX,4C00H INT 21HSUB1 PROC PUSH AX MOV DX,0 MOV CX,COUNTAGAIN: RCR AL,1 JNC L INC DXL: LOOP AGAIN POP AX TEST DX,01 JZ QUIT OR AL,80HQUIT: RETSUB1 ENDPCODE ENDSEND START17(19)試編寫程序?qū)崿F(xiàn)將鍵盤輸入的小寫字母轉(zhuǎn)換成大寫字母并輸出。解答:DATA SEGMENTMESS DB THE INPUT IS NOT CORRECT.,0DH,0AH,$DATA ENDSSTACK SEGMENTSTACK ENDSCODE SEGMENTASSUME DS:DATA,CS:CODE,SS:STACK,ES:DATASTART: MOV AX,DATA MOV DS,AXNEXT: MOV AH,01H INT 21H CMP AL,Q JZ EXIT CMP AL,a JB ERROR CMP AL,z JA ERROR SUB AL,20H MOV AH,02H MOV DL,AL INT 21H JMP NEXTERROR: MOV AH,09H LEA DX,MESS INT 21H JMP NEXTEXIT: MOV AX,4C00H INT 21HCODE ENDSEND START18從鍵盤接收20個字符,按鍵入順序查找最大的字符,并顯示輸出。解答:DATA SEGMENTDAT DB 20 DUP(?)DATA ENDSSTACK SEGMENTSTACK ENDSCODE SEGMENTASSUME DS:DATA,CS:CODE,SS:STACK,ES:DATASTART: MOV AX,DATA MOV DS,AX;從鍵盤接收20個字符,并送DAT中保存LEA SI,DATMOV CX,20NEXT:MOV AH,01HINT 21HMOV SI,ALINC SILOOP NEXT;比較20個字符中的最大字符,并放入AL中 MOV CX,19LEA SI,DATMOV AL,SIINC SINEXT1:CMP AL,SIJAE LLMOV AL,SILL:INC SILOOP NEXT1;將最大的字符的ASCII碼由AL送DL顯示MOV DL,ALMOV AH,2HINT 21H;返回DOS MOV AX,4C00H INT 21HCODE ENDSEND START19(29)編寫匯編程序,接收從鍵盤輸入的10個數(shù),輸入回車符表示結(jié)束,然后將這些數(shù)加密后存于BUFF緩沖區(qū)中。加密表為:輸入數(shù)字:0,1,2,3,4,5,6,7,8,9;密碼數(shù)字:7,5,9,1,3,6,8,0,2,4解答:DATA SEGMENTBUFF DB 10 DUP(?)TABLE DB 7,5,9,1,3,6,8,0,2,4DATA ENDSSTACK SEGMENTSTACK ENDSCODE SEGMENTASSUME DS:DATA,CS:CODE,SS:STACK,ES:DATASTART: MOV AX,DATA MOV DS,AX;LEA DI,BUFFNEXT:MOV AH,01HINT 21H;從鍵盤上接收單個字符CMP AL,0AH;與0AH比,判是否要結(jié)束JZ EXITSUB AL,30H;否則,將09的ASCII碼轉(zhuǎn)換為十進制數(shù)LEA BX,TABLEXLAT;用查表指令進行加密MOV DI,ALINC DIJMP NEXT;退出并返回DOSEXIT: MOV AX,4C00H INT 21HCODE ENDSEND START20(23)有一個100個字節(jié)的數(shù)據(jù)表,表內(nèi)元素已按從大到小的順序排列好,現(xiàn)給定一元素,試編程序在表內(nèi)查找,若表內(nèi)已有此元素,則結(jié)束;否則,按順序?qū)⒋嗽夭迦氡碇羞m當?shù)奈恢茫⑿薷谋黹L。(略)21(26)在當前數(shù)據(jù)段(DS),偏移地址為DATAB開始的順序80個單元中,存放著某班80個同學(xué)某門考試成績。按要求編寫程序: 編寫程序統(tǒng)計90分;80分89分;70分79分;60分69分,60分的人數(shù)各為多少,并將結(jié)果放在同一數(shù)據(jù)段、偏移地址為BTRX開始的順序單元中。 試編程序,求該班這門課的平均成績?yōu)槎嗌?,并放在該?shù)據(jù)段的AVER單元中。解答:;統(tǒng)計學(xué)生成績DATA SEGMENTDATAB DB X1,X2,.,X80N EQU $-DATABORG 100HBTRX DW 0S8 DW 0S7DW 0S6DW 0S5DW 0ORG 110HAVER DW ?DATAENDSSTACKSEGMENT STACKSTA DB 20 DUP (0) TOP EQU $STASTACK ENDSCODESEGMENTMAINPROC FARASSUME CS:CODE, DS:DATA, SS:STACKSTART: PUSH DSSUB AX,AX PUSH AXMOV AX,DATAMOV DS,AXMOV CX,NMOV BX,0000HMOV DX,0000HLEA SI,DATAB ;成績表首地址COMPARE:MOV AL,SICMP AL,60 ;60?JL FIVECMP AX,70 ;70?JL SIXCMP AX,80 ;80?JL SEVENCMP AX,90 ;90?JL EIGHTINC S9JMP CHAEIGHT: INC S8JMP CHASEVEN:INC S7JMP CHASIX:INC S6JMP CHAFIVE: INC S5JMP CHACHA: ADD BX,ALJNC NEXTADC DX,0 NEXT:INC SI ;循環(huán)學(xué)生人數(shù)LOOP COMPAREMOV AX,BXMOV CX,NDIV CXMOV AVER,AXMOV AH,4CHINT 21HRETMAIN ENDPCODE ENDS END STARTCH04 存儲系統(tǒng)習(xí)題與思考題1存儲器的哪一部分用來存儲程序指令及像常數(shù)和查找表一類的固定不變的信息?哪一部分用來存儲經(jīng)常改變的數(shù)據(jù)?解答:只讀存儲器ROM;隨機存儲器RAM。2術(shù)語“非易失性存儲器”是什么意思?PROM和EPROM分別代表什么意思?解答:“非易失性存儲器”是指當停電后信息會丟失;PROM-可編程序的只讀存儲器PROM(Programmable ROM),EPROM-可擦除的可編程的只讀存儲器EPROM(Erasible Programmable ROM)。3微型計算機中常用的存儲器有哪些?它們各有何特點?分別適用于哪些場合?解答:(略)4現(xiàn)代計算機中的存儲器系統(tǒng)采用了哪三級分級結(jié)構(gòu),主要用于解決存儲器中存在的哪些問題?解答:目前在計算機系統(tǒng)中通常采用三級存儲器結(jié)構(gòu),即使用高速緩沖存儲器、主存儲器和輔助存儲器,由這三者構(gòu)成一個統(tǒng)一的存儲系統(tǒng)。從整體看,其速度接近高速緩存的速度,其容量接近輔存的容量,而位成本則接近廉價慢速的輔存平均價格。三級結(jié)構(gòu)主要用于解決速度、容量和成本的問題。5試比較靜態(tài)RAM和動態(tài)RAM的優(yōu)缺點,并說明有何種方法可解決掉電時動態(tài)RAM中信息的保護。解答:靜態(tài)RAM-存儲一位信- 1.請仔細閱讀文檔,確保文檔完整性,對于不預(yù)覽、不比對內(nèi)容而直接下載帶來的問題本站不予受理。
- 2.下載的文檔,不會出現(xiàn)我們的網(wǎng)址水印。
- 3、該文檔所得收入(下載+內(nèi)容+預(yù)覽)歸上傳者、原創(chuàng)作者;如果您是本文檔原作者,請點此認領(lǐng)!既往收益都歸您。
下載文檔到電腦,查找使用更方便
32 積分
下載 |
- 配套講稿:
如PPT文件的首頁顯示word圖標,表示該PPT已包含配套word講稿。雙擊word圖標可打開word文檔。
- 特殊限制:
部分文檔作品中含有的國旗、國徽等圖片,僅作為作品整體效果示例展示,禁止商用。設(shè)計者僅對作品中獨創(chuàng)性部分享有著作權(quán)。
- 關(guān) 鍵 詞:
- 微型計算機 原理 應(yīng)用 課后 答案 侯曉霞
鏈接地址:http://italysoccerbets.com/p-1572780.html