




版權(quán)說明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請(qǐng)進(jìn)行舉報(bào)或認(rèn)領(lǐng)
文檔簡(jiǎn)介
1、第 1 章基礎(chǔ)知識(shí)1.1 計(jì)算機(jī)中常用的計(jì)數(shù)制有哪些?解:二進(jìn)制、八進(jìn)制、十進(jìn)制(BCD)、十六進(jìn)制。1.2 什么是機(jī)器碼?什么是真值?解:把符號(hào)數(shù)值化的數(shù)碼稱為機(jī)器數(shù)或機(jī)器碼,原來的數(shù)值叫做機(jī)器數(shù)的真值。1.3 完成下列數(shù)制的轉(zhuǎn)換。微型計(jì)算機(jī)的基本工作原理匯編語(yǔ)言程序設(shè)計(jì)微型計(jì)算機(jī)接口技術(shù)建立微型計(jì)算機(jī)系統(tǒng)的整體概念,形成微機(jī)系統(tǒng)軟硬件開發(fā)的初步能力。解:( 1) 166, A6H( 2) 0.75( 3) 11111101.01B, FD.4H(4 ) 5B.AH, (10010001.011000100101)BCD1.4 8位和 16位二進(jìn)制數(shù)的原碼、補(bǔ)碼和反碼可表示的數(shù)的范圍分別是多
2、少?解:原碼(-127+127)、(-32767+32767)補(bǔ)碼(-128+127)、(-32768+32767)反碼(-127+127)、(-32767+32767)1.5 寫出下列真值對(duì)應(yīng)的原碼和補(bǔ)碼的形式。( 1) X= -1110011B( 2) X= -71D( 3) X= +1001001B解:(1)原碼:11110011補(bǔ)碼:10001101(2)原碼:11000111補(bǔ)碼:10111001(3)原碼:01001001補(bǔ)碼:010010011.6 寫出符號(hào)數(shù)10110101B的反碼和補(bǔ)碼。解:11001010, 110010111.7 已知 X 和 Y 的真值,求X+Y 的補(bǔ)碼
3、。( 1) X=-1110111B Y=+1011010B( 2) X=56D Y= -21D解:( 1) 11100011( 2) 001000111.8 已知 X= -1101001B, Y= -1010110B,用補(bǔ)碼求 X-Y 的值。解: 111011011.9 請(qǐng)寫出下列字符的ASCII 碼。4A3- !解:34H, 41H, 33H, 3DH, 21H1.10 若給字符4 和 9 的 ASCII 碼加奇校驗(yàn),應(yīng)是多少?解:34H, B9H1.11 上題中若加偶校驗(yàn),結(jié)果如何?解:B4H, 39H1.12 計(jì)算下列表達(dá)式。 1) ( 4EH+10110101B) x( 0.0101)
4、 BCD=() D 2) 2) 4EH-( 24/08H+ B /2) =() B解:( 1) 129.5D( 2) 101010B第 2 章微型計(jì)算機(jī)基礎(chǔ)2.6 簡(jiǎn)述CPU執(zhí)行程序的過程。解:當(dāng)程序的第一條指令所在的地址送入程序計(jì)數(shù)器后,CPU 就進(jìn)入取指階段準(zhǔn)備取第一條指令。在取指階段,CPU 從內(nèi)存中讀出指令,并把指令送至指令寄存器 IR 暫存。在取指階段結(jié)束后,機(jī)器就進(jìn)入執(zhí)行階段,這時(shí),由指令譯碼器對(duì)指令譯碼,再經(jīng)控制器發(fā)出相應(yīng)的控制信號(hào),控制各部件執(zhí)行指令所規(guī)定的具體操作。當(dāng)一條指令執(zhí)行完畢以后,就轉(zhuǎn)入了下一條指令的取指階段。以上步驟周而復(fù)始地循環(huán),直到遇到停機(jī)指令。2.7 說明80
5、86的 EU 和 BIU 的主要功能。在執(zhí)行程序過程中他們是如何相互配合工作的?解: 執(zhí)行單元EU 負(fù)責(zé)執(zhí)行指令。EU 在工作時(shí)不斷地從指令隊(duì)列取出指令代碼,對(duì)其譯碼后產(chǎn)生完成指令所需要的控制信息。數(shù)據(jù)在ALU 中進(jìn)行運(yùn)算,運(yùn)算結(jié)果的特征保留在標(biāo)志寄存器FLAGS 中。 總線接口單元BIU 負(fù)責(zé) CPU 與存儲(chǔ)器、I/O 接口之間的信息傳送。BIU 取出的指令被送入指令隊(duì)列供EU 執(zhí)行, BIU 取出的數(shù)據(jù)被送入相關(guān)寄存器中以便做進(jìn)一步的處理。當(dāng) EU 從指令隊(duì)列中取走指令,指令隊(duì)列出現(xiàn)空字節(jié)時(shí),BIU 就自動(dòng)執(zhí)行一次取指令周期,從內(nèi)存中取出后續(xù)的指令代碼放入隊(duì)列中。當(dāng)EU 需要數(shù)據(jù)時(shí),BIU
6、 根據(jù) EU 給出的地址,從指定的內(nèi)存單元或外設(shè)中取出數(shù)據(jù)供EU 使用。當(dāng)運(yùn)算結(jié)束時(shí),BIU 將運(yùn)算結(jié)果送入指定的內(nèi)存單元或寄存器。當(dāng)指令隊(duì)列空時(shí),EU 就等待,直到有指令為止。若BIU 正在取指令, EU 發(fā)出訪問總線的請(qǐng)求,則必須等BIU 取指令完畢后,該請(qǐng)求才能得到響應(yīng)。一般情況下,程序順序執(zhí)行,當(dāng)遇到跳轉(zhuǎn)指令時(shí),BIU 就使指令隊(duì)列復(fù)位,從新地址取出指令,并立即傳送EU 去執(zhí)行。指令隊(duì)列的存在使8086/8088的 EU 和 BIU 并行工作,從而減少了CPU 為取指令而等待的時(shí)間,提高了CPU 的利用率,加快了整機(jī)的運(yùn)行速度。另外也降低了對(duì)存儲(chǔ)器存取速度的要求。2.8 在執(zhí)行指令期間
7、,BIU 能直接訪問存儲(chǔ)器嗎?為什么?解 :可以.因?yàn)镋U 和 BIU 可以并行工作,EU 需要的指令可以從指令隊(duì)列中獲得,這時(shí) BIU 預(yù)先從存儲(chǔ)器中取出并放入指令隊(duì)列的。在 EU 執(zhí)行指令的同時(shí),BIU 可以訪問存儲(chǔ)器取下一條指令或指令執(zhí)行時(shí)需要的數(shù)據(jù)。2.9 8086與8088CPU的主要區(qū)另I有哪些?解:主要區(qū)別有以下幾點(diǎn): 8086的外部數(shù)據(jù)總線有16位,而8088的外部數(shù)據(jù)總線只有8位。 8086指令隊(duì)列深度為6個(gè)字節(jié),而 8088的指令隊(duì)列深度為4個(gè)字節(jié) .因?yàn)?8086 的外部數(shù)據(jù)總線有16 位 ,故 8086 每個(gè)總線周期可以存取兩個(gè)字節(jié).而 8088 的外部數(shù)據(jù)總線因?yàn)橹挥?/p>
8、8 位 ,所以每個(gè)總線周期只能存取1 個(gè)字節(jié) .個(gè)別引腳信號(hào)的含義稍有不同.2.10 8088CPU工作在最小模式下:( 1)當(dāng)CPU 訪問存儲(chǔ)器時(shí),要利用哪些信號(hào)?( 2)當(dāng)CPU 進(jìn)行 I/O 操作時(shí),要利用哪些信號(hào)?( 3)當(dāng)HOLD 有效并得到響應(yīng)時(shí),CPU 的哪些信號(hào)置高阻?解:( 1)要利用信號(hào)線包括WR#、 RD#、 IO/M#、 ALE 以及 AD0AD7 、 A8A19。( 2)同(1)。( 3)所有三態(tài)輸出的地址信號(hào)、數(shù)據(jù)信號(hào)和控制信號(hào)均置為高阻態(tài)。2.11 總線周期中,什么情況下要插入TW 等待周期?插入TW 周期的個(gè)數(shù),取決于什么因素?解:在每個(gè)總線周期的T3 的開始處
9、若READY 為低電平,則CPU 在 T3 后插入一個(gè)等待周期TW。 在 TW 的開始時(shí)刻,CPU 還要檢查READY 狀態(tài), 若仍為低電平, 則再插入一個(gè)TW 。 此過程一直進(jìn)行到某個(gè)TW 開始時(shí), READY 已經(jīng)變?yōu)楦唠娖?,這時(shí)下一個(gè)時(shí)鐘周期才轉(zhuǎn)入T4??梢钥闯觯迦隩W 周期的個(gè)數(shù)取決于READY 電平維持的時(shí)間。2.12 若 8088工作在單CPU 方式下,在教材第91 頁(yè)的表中填入不同操作時(shí)各控制信號(hào)的狀態(tài)。解:結(jié)果如表所示。2.13 在8086/8088 CPU中,標(biāo)志寄存器包含哪些標(biāo)志位?各位為 0 (為1)分別表示什么含義?解:(略),見書第49 頁(yè)。2.14 8086/80
10、88 CPU中,有哪些通用寄存器和專用寄存器?說明它們的作用。解:通用寄存器包含以下8 個(gè)寄存器:AX、 BX、 CX 和 DX 寄存器一般用于存放參與運(yùn)算的數(shù)據(jù)或運(yùn)算的結(jié)果。除此之外:AX:主要存放算術(shù)邏輯運(yùn)算中的操作數(shù),以及存放I/O操作的數(shù)據(jù)。BX:存放訪問內(nèi)存時(shí)的基地址。CX:在循環(huán)和用操作指令中用作計(jì)數(shù)器。DX:在寄存器間接尋址的I/O指令中存放I/O地址。在做雙字長(zhǎng)乘除法運(yùn)算時(shí),DX 與 AX 合起來存放一個(gè)雙字長(zhǎng)數(shù)。SP:存放棧頂偏移地址。BP:存放訪問內(nèi)存時(shí)的基地址。SP和BP也可以存放數(shù)據(jù),但它們的默認(rèn)段寄存器都是 SS。SI:常在變址尋址方式中作為源地址指針。DI:常在變址
11、尋址方式中作為目標(biāo)地址指針。專用寄存器包括4 個(gè)段寄存器和兩個(gè)控制寄存器:CS:代碼段寄存器,用于存放代碼段的段基地址。DS:數(shù)據(jù)段寄存器,用于存放數(shù)據(jù)段的段基地址。SS:堆棧段寄存器,用于存放堆棧段的段基地址。ES:附加段寄存器,用于存放附加段的段基地址。IP:指令指針寄存器,用于存放下一條要執(zhí)行指令的偏移地址。FLAGS:標(biāo)志寄存器,用于存放運(yùn)算結(jié)果的特征。2.15 8086/8088 系統(tǒng)中, 存儲(chǔ)器為什么要分段?一個(gè)段最大為多少個(gè)字節(jié)?最小為多少個(gè)字節(jié)?解:分段的主要目的是便于存儲(chǔ)器的管理,使得可以用16 位寄存器來尋址20位的內(nèi)存空間。一個(gè)段最大為 64KB,最小為16B。2.16
12、在 8086/8088 CPU 中,物理地址和邏輯地址是指什么?已知邏輯地址為1F00: 38A0H ,如何計(jì)算出其對(duì)應(yīng)的物理地址?解:物理地址時(shí)CPU 存取存儲(chǔ)器所用的地址。邏輯地址是段和偏移地址形式的地址,即匯編語(yǔ)言程序中使用的存儲(chǔ)器地址。若 已 知 邏 輯 地 址 為 1F00: 38A0H , 則 對(duì) 應(yīng) 的 物 理 地 址 =1F00H x 16+38A0H=228A0H。2.17 已知存儲(chǔ)器物理地址為78A00H, 計(jì)算出它所對(duì)應(yīng)的邏輯地址。此結(jié)果惟一嗎?解:物理地址可以對(duì)應(yīng)于不同的邏輯地址。78A00H 對(duì)應(yīng)的邏輯地址可以是7000H: 8A00H, 7800H: 0A00H,
13、78A0H: 0000H 等。結(jié)果不是惟一的。2.18 設(shè)當(dāng)前數(shù)據(jù)段位于存儲(chǔ)器的 A8000HB7FFFH , DS段寄存器的內(nèi)容應(yīng)是什么?解:因?yàn)锳8000H到B7FFFH之間的地址范圍大小為64KB ,未超出一個(gè)段的最大范圍。故要訪問此地址范圍的數(shù)據(jù),數(shù)據(jù)段的起始地址(即段首地址)應(yīng)為A8000H, WJ DS 段寄存器為 A800H。2.19 若CS=8000H,則當(dāng)前代碼段可尋址的存儲(chǔ)空間的范圍是多少?解(CS) =8000H 時(shí),當(dāng)前代碼段可尋址的存儲(chǔ)空間范圍為80000H8FFFFH。2.20 8086/8088 CPU 在最小模式下構(gòu)成計(jì)算機(jī)系統(tǒng)至少應(yīng)包括哪幾個(gè)基本部分(器件)?
14、解:其至少應(yīng)包括:8088CPU、 8284時(shí)鐘發(fā)生器、8282鎖存器(3 片)和 8286雙向總線驅(qū)動(dòng)器。第 3 章 8088/8086 指令系統(tǒng)3.1 什么叫尋址方式? 8086/8088CPU共有哪幾種尋址方式?解:尋址方式主要是指獲得操作數(shù)所在地址的方法 .8086/8088CPU具有:立即尋址、直接尋址、寄存器尋址、寄存器間接尋址、寄存器相對(duì)尋址、基址一變址尋址、基址一變址相對(duì)尋址以及隱含尋址等8 種尋址方式。3.2 設(shè) ( DS)=6000H, ( ES)=2000H, ( SS)=1500H, ( Si) =00A0H,( BX)=0800H , (BP)=1200H,數(shù)據(jù)變量V
15、AR為0050H.請(qǐng)分別指出下列各條指令源操作數(shù)的尋 址方式?它的物理地址是多少?(1) MOV AX,BX (2) MOV DL,80H(3) MOV AX, VAR (4) MOV AX,VARBXSI(5) MOV AL,'B' (6) MOV DI, ES: BX(7) MOV DX,BP (8) MOV BX , 20HBX解:(1)寄存器尋址。因源操作數(shù)是寄存器,故寄存器BX 就是操作數(shù)的地址.(2)立即尋址。操作數(shù)80H 存放于代碼段中指令碼MOV 之后。(3)直接尋址。( 4)基址一變址一相對(duì)尋址操作數(shù)的物理地址=(DS) X 16+(SI)+(BX) + VA
16、R=60000H + 00A0H + 0800H + 0050H= 608F0H(5)立即尋址(6)寄存器間接尋址.操作數(shù)的物理地址=(ES) X 16+(BX)= 20000H 0800H = 20800H(7)寄存器間接尋址。操作數(shù)的物理地址=(SS) X 16+(BP)= 15000H 1200H= 16200H(8)寄存器相對(duì)尋址操作數(shù)的物理地址=(DS) X 16+(BX)+20H= 60000H 0800H 20H= 60820H3.3 假 設(shè) (DS)= 212AH,(CS)= 0200H,(IP)= 1200H,(BX)= 0500H, 位 移 量 DATA=40H , (21
17、7A0H) =2300H, (217E0H)=0400H, (217E2H) =9000H試確定下列轉(zhuǎn)移指令的轉(zhuǎn)移地址.(1) JMP 2300H(2) JMP WORD PTRBX(3) JMP DWORD PTRBX+DATA解: 轉(zhuǎn)移指令分為段內(nèi)轉(zhuǎn)移和段間轉(zhuǎn)移,根據(jù)其尋址方式的不同,又有段內(nèi)的直接轉(zhuǎn)移和間接轉(zhuǎn)移,以及段間的直接轉(zhuǎn)移和間接轉(zhuǎn)移地址。對(duì)直接轉(zhuǎn)移,其轉(zhuǎn)移地址為當(dāng)前指令的偏移地址(即IP 的內(nèi)容)加上位移量或由指令中直接得出;對(duì)間接轉(zhuǎn)移,轉(zhuǎn)移地址等于指令中寄存器的內(nèi)容或由寄存器內(nèi)容所指向的存儲(chǔ)單元的內(nèi)容。 段內(nèi)直接轉(zhuǎn)移。轉(zhuǎn)移的物理地址 二(CS) X 16 +2300H=0200
18、0H+2300H=04300H(2)段內(nèi)間接轉(zhuǎn)移。轉(zhuǎn)移的物理地址=(CS) X 16+ BX=(CS) Xl6+(217A0H)=02000H+2300H=04300H(3)段間間接轉(zhuǎn)移。轉(zhuǎn)移的物理地址=BX+DATA=(217E2H) Xl6+(217E0H)=90000H+0400H=90400H3.4 試說明指令MOV BX,5BX 與指令 LEA BX,5BX 的區(qū)別。解:前者是數(shù)據(jù)傳送類指令,表示將數(shù)據(jù)段中以 (BX+5)為偏移地址的16位數(shù)據(jù)送寄存器BX.后者是取偏移地址指令,執(zhí)行的結(jié)果是(BX) = (BX) 5, 即操作數(shù)的偏移地址為(BX)+5。3.5 設(shè)堆棧指針SP的初值為
19、2300H,(AX) =50ABH ,(BX)=1234H。執(zhí)行指令PUSH AX 后,(SP)=?,再執(zhí)行指令 PUSH BX 及 POP AX 之后,(SP)= ? (AX ) = ? (BX) = ?解:堆棧指針SP總是指向棧頂,每執(zhí)行一次 PUSH指令SP-2,執(zhí)行一次POP 指令SP+2所以,執(zhí)行PUSH AX指令后,(SP)=22FEH;再執(zhí)行PUSH BX及POP AX 后, (SP)=22FEH, (AX)=(BX)=1234H3.6 指出下列指令的錯(cuò)誤:(1) MOV AH , CX (2) MOV 33H , AL(3) MOV AX, SIDI (4) MOV BX ,
20、SI(5) ADD BYTE PTRBP,256 (6) MOV DATASI,ES:AX(7) JMP BYTE PTRBX (8) OUT 230H,AX(9) MOV DS,BP (10) MUL 39H解:(1)指令錯(cuò)。兩操作數(shù)字長(zhǎng)不相等(2)指令錯(cuò)。MOV 指令不允許目標(biāo)操作數(shù)為立即數(shù)(3) 指令錯(cuò)。在間接尋址中不允許兩個(gè)間址寄存器同時(shí)為變址寄存器。(4)指令錯(cuò)。MUV 指令不允許兩個(gè)操作數(shù)同時(shí)為存儲(chǔ)器操作數(shù)。(5)指令錯(cuò)。ADD 指令要求兩操作數(shù)等字長(zhǎng)。(6)指令錯(cuò)。源操作數(shù)形式錯(cuò),寄存器操作數(shù)不加段重設(shè)符。(7)指令錯(cuò)。轉(zhuǎn)移地址的字長(zhǎng)至少應(yīng)是16 位的。(8)指令錯(cuò)。對(duì)輸人輸出指
21、令,當(dāng)端口地址超出8 位二進(jìn)制數(shù)的表達(dá)范圍(即尋址的端口超出256 個(gè))時(shí),必須采用間接尋址。(9)指令正確。(10)指令錯(cuò)。MUL 指令不允許操作數(shù)為立即數(shù)。3.7 已知 (AL) =7BH, (BL) =38H, 試問執(zhí)行指令A(yù)DD AL, BL 后 ,AF、 CF、 OF、 PF、SF 和 ZF 的值各為多少?解: AF=1 , CF=0, OF=1, PF=0, SF=l, ZF=03.8 試比較無(wú)條件轉(zhuǎn)移指令、條件轉(zhuǎn)移指令、調(diào)用指令和中斷指令有什么異同?解: 無(wú)條件轉(zhuǎn)移指令的操作是無(wú)條件地使程序轉(zhuǎn)移到指定的目標(biāo)地址,并從該地址開始執(zhí)行新的程序段,其轉(zhuǎn)移的目標(biāo)地址既可以是在當(dāng)前邏輯段,
22、也可以是在不同的邏輯段;條件轉(zhuǎn)移指令是在滿足一定條件下使程序轉(zhuǎn)移到指定的目標(biāo)地址,其轉(zhuǎn)移范圍很小,在當(dāng)前邏輯段的-128+127地址范圍內(nèi)。調(diào)用指令是用于調(diào)用程序中常用到的功能子程序,是在程序設(shè)計(jì)中就設(shè)計(jì)好的。根據(jù)所調(diào)用過程人口地址的位置可將調(diào)用指令分為段內(nèi)調(diào)用(入口地址在當(dāng)前邏輯段內(nèi))和段間調(diào)用。在執(zhí)行調(diào)用指令后,CPU要保護(hù)斷點(diǎn)。對(duì)段內(nèi)調(diào)用是將其下一條指令的偏移地址壓人堆棧,對(duì)段間調(diào)用則要保護(hù)其下一條指令的偏移地址和段基地址,然后將子程序人口地址賦給IP (或CS 和 IP)中斷指令是因一些突發(fā)事件而使CPU 暫時(shí)中止它正在運(yùn)行的程序,轉(zhuǎn)去執(zhí)行一組專門的中斷服務(wù)程序,并在執(zhí)行完后返回原被中
23、止處繼續(xù)執(zhí)行原程序。它是隨機(jī)的。在響應(yīng)中斷后CPU 不僅要保護(hù)斷點(diǎn)(即INT 指令下一條指令的段地址和偏移地址),還要將標(biāo)志寄存器FLAGS 壓入堆棧保存。3.9 試判斷下列程序執(zhí)行后,BX 中的內(nèi)容MOV CL, 3MOV BX,0B7HROL BX,1ROR BX,CL解:該程序段是首先將BX 內(nèi)容不帶進(jìn)位循環(huán)左移1 位,再循環(huán)右移3 位。即相當(dāng)于將原BX 內(nèi)容不帶進(jìn)位循環(huán)右移2 位,故結(jié)果為:(BX)=0C02DH3.10 按下列要求寫出相應(yīng)的指令或程序段。(1)寫出兩條使AX 內(nèi)容為 0 的指令。(2)使 BL 寄存器中的高4位和低 4位互換。(3)屏蔽CX寄存器的bll,b7和b3位
24、。(4)測(cè)試DX 中的 b0 和 b8 位是否為1。解:(1)MOV AX,0XOR AX,AX ;AX 寄存器自身相異或,可使其內(nèi)容清0(2)MOV CL, 4ROL BL,CL ; 將 BL 內(nèi)容循環(huán)左移4位,可實(shí)現(xiàn)其高4位和低 4位 的互換(3)AND CX,0F777H ;將 CX 寄存器中需屏蔽的位“與 ” 0。也可用“或 ”指令實(shí)現(xiàn)(4)AND DX,0101H ;將需側(cè)試的位“與 ” 1,其余“與 ”0屏蔽掉CMP DX,0101 H ;與 0101H 比較JZ ONE ;若相等則表示b0和b8位同時(shí)為1 .3.11 分別指出以下兩個(gè)程序段的功能:(1) (2)MOV CX,l0
25、 CLDLEA SI,FIRST LEA DI, 1200HLEA DI, SECOND MOV CX,0FOOHSTD XOR AX,AXREP MOVSB REP STOSW解:(1)該段程序的功能是:將數(shù)據(jù)段中FIRST 為最高地址的10 個(gè)字節(jié)數(shù)據(jù)按減地址方向傳送到附加段SECOND 為最高地址的向前10 個(gè)單元中。(2)將附加段中偏移地址為1200H 單元開始的0FOOH 個(gè)字單元清0。1.12 執(zhí)行以下兩條指令后,標(biāo)志寄存器FLAGS 的六個(gè)狀態(tài)位各為什么狀態(tài)?MOV AX,84A0HADD AX,9460H解:執(zhí)行ADD 指令后,6 個(gè)狀態(tài)標(biāo)志位的狀態(tài)分別為:在兩個(gè) 16 位數(shù)進(jìn)
26、行加法運(yùn)算時(shí),對(duì)CF、 ZF、 SF 和 OF 會(huì)產(chǎn)生影響,但對(duì)PF 和AF 標(biāo)志位,只有其低8位的運(yùn)算影響它們的狀態(tài)。各標(biāo)志位的狀態(tài)分別為:AF=0,PF=1, CF=1, ZF=0, SF=0, OF=1。1.13 將 +46和 -38 分別乘以2,可應(yīng)用什么指令來完成?如果除以2 呢?解:因?yàn)閷?duì)二進(jìn)制數(shù),每左移一位相當(dāng)于乘以2,右移一位相當(dāng)于除以2。所以,將+46和-38分別乘以2,可分別用邏輯左移指令(SHL)和算術(shù)左移指令(SAL)完成。 SHL 指令針對(duì)無(wú)符號(hào)數(shù),SAL 指令針對(duì)有符號(hào)數(shù)。當(dāng)然,也可以分別用無(wú)符號(hào)數(shù)乘法指令MUL 和有符號(hào)數(shù)乘法指令I(lǐng)MUL 完成。如果是除以2,則進(jìn)
27、行相反操作,即用邏輯右移指令SHR或無(wú)符號(hào)數(shù)除法指令DIV實(shí)現(xiàn) +46除以 2 的運(yùn)算, 用算術(shù)右移指令SAR 或有符號(hào)數(shù)除法指令I(lǐng)DIV 實(shí)現(xiàn) -38除以 2 的運(yùn)算。1.14 已知 AX=8060H,DX=03F8H , 端口 PORT1 的地址是48H, 內(nèi)容為 40H; PORT2的地址是84H,內(nèi)容為85H。請(qǐng)指出下列指令執(zhí)行后的結(jié)果。(1)OUT DX, AL(2) IN AL,PORT1(3) OUT DX,AX(4) IN AX,48H(5) OUT PORT2,AX解:(1)將 60H 輸出到地址為03F8H 的端口中。(2) 從 PORT1 讀入一個(gè)字節(jié)數(shù)據(jù),執(zhí)行結(jié)果:(A
28、L)=40H 。(3) 將 AX=8060H 輸出到地址為03F8H 的端口中。(4)由 48H 端口讀人16 位二進(jìn)制數(shù)。(5)將 8060H 輸出到地址為84H 的端口中。第 4 章匯編語(yǔ)言程序設(shè)計(jì)4.1 請(qǐng)分別用DB 、 DW 、 DD 偽指令寫出在DATA 開始的連續(xù)8個(gè)單元中依次存放數(shù)據(jù)11H 、 22H 、 33H 、 44H 、 55H 、 66H 、 77H 、 88H 的數(shù)據(jù)定義語(yǔ)句.解 :DB,DW,DD 偽指令分別表示定義的數(shù)據(jù)為字節(jié)類型、字類型及雙字型.其定義形式為 :DATA DB 11H,22H,33H,44H,55H,66H,77H,88HDATA DW 2211
29、H,4433H,6655H,8877HDATA DD 44332211H,88776655H4.2 若程序的數(shù)據(jù)段定義如下,寫出各指令語(yǔ)句獨(dú)立執(zhí)行后的結(jié)果:DSEG SEGMENTDATA1 DB 10H,20H,30HDATA2 DW 10 DUP(?)STRING DB 123DSEG ENDS(1) MOV AL,DATA1(2) MOV BX,OFFSET DATA2(3) LEA SI,STRINGADD DI,SI解:取變量 DATA1 的值 . 指令執(zhí)行后,(AL)=10H.變量 DATA2 的偏移地址. 指令執(zhí)行后,(BX)=0003H.(3)先取變量STRING的偏移地址送寄
30、存器SI,之后送SI的內(nèi)容與DI的內(nèi)容相加并將結(jié)果送 DI.指令執(zhí)行后,(SI)=0017H;(DI)=(DI)+0017H.4.3 試編寫求兩個(gè)無(wú)符號(hào)雙子長(zhǎng)數(shù)之和的程序. 兩數(shù)分別在MEM1 和 MEM2 單元中,和放在SUM 單元 .解:DSEG SEGMENTMEM1 DW 1122H,3344HMEM2 DW 5566H,7788HSUM DW 2 DUP(?)DSEG ENDSCSEG SEGMENTASSUME CS:CSEG,DS:DSEGSTART: MOV AX,DSEGMOV DS,AXLEA BX,MEM1LEA SI,MEM2LEA DI,SUMMOV CL,2CLCA
31、GAIN: MOV AX,BXADC AX,SIMOV DI,AXADD BX,2ADD SI,2ADD DI,2LOOP AGAINHLTCSEG ENDSEND START4.4 試編寫程序,測(cè)試AL寄存器的第4位(bit4)是否為0?解 : 測(cè)試寄存器AL 中某一位是否為0,可使用TEST 指令、 AND 指令、 移位指令等幾種方法實(shí)現(xiàn)。如: TEST AL, 10HJZ NEXTNEXT:或者:MOV CL , 4SHL AL , CLJNC NEXTNEXT:4.7 執(zhí)行下列指令后,AX 寄存器的內(nèi)容是多少?TABLE DW 10 , 20, 30, 40, 50ENTRY DW 3
32、MOV BX, OFFSET TABLEADD BX , ENTRYMOV AX , BX解:( AX) =1E00H4.12 畫圖說明下列語(yǔ)句分配的存儲(chǔ)空間及初始化的數(shù)據(jù)值。( 1) DATA1 DB BYTE, 12, 12H, 2 DUP( 0,?,3)( 2) DATA2 DW 4 DUP ( 0, 1, 2),?,-5, 256H解:(1)存儲(chǔ)空間分配情況如圖(a)所示。(2)存儲(chǔ)空間分配情況如圖(b)所示。第 5 章存儲(chǔ)器系統(tǒng)1.1 內(nèi)部存儲(chǔ)器主要分為哪兩類? 它們的主要區(qū)別是什么?解 : ( 1 )分為 ROM 和 RAM 。( 2)它們之間的主要區(qū)別是:ROM在正常工作時(shí)只能讀
33、出,不能寫入。RAM則可讀可寫。斷電后,ROM中的內(nèi)容不會(huì)丟失,RAM中的內(nèi)容會(huì)丟失。1.6 若采用6264芯片構(gòu)成上述的內(nèi)存空間,需要多少片6264芯片?解:每個(gè)6264芯片的容量位8KB,故需432/8 =54片。1.7 設(shè)某微型機(jī)的內(nèi)存RAM 區(qū)的容量位128KB ,若用 2164 芯片構(gòu)成這樣的存儲(chǔ)器,需多少2164 芯片?至少需多少根地址線?其中多少根用于片內(nèi)尋址?多少根用于片選譯碼?解:(1)每個(gè)2164芯片的容量為64Kx 1bit,共需128/64X8= 16片。( 2) 128KB容量需要地址線17根。( 3) 16 根用于片內(nèi)尋址。( 4) 1 根用于片選譯碼。注意,用于片
34、內(nèi)尋址的16 根地址線要通過二選一多路器連到2164 芯片,因?yàn)?164芯片是DRAM,高位地址與低位地址是分時(shí)傳送的。5.9 甚什么是字?jǐn)U展?什么是位擴(kuò)展?用戶自己購(gòu)買內(nèi)存條進(jìn)行內(nèi)存擴(kuò)充,是在進(jìn)行何種存儲(chǔ)器擴(kuò)展?解:( 1)當(dāng)存儲(chǔ)芯片的容量小于所需內(nèi)存容量時(shí),需要用多個(gè)芯片構(gòu)成滿足容量要求的存儲(chǔ)器,這就是字?jǐn)U展。( 2)當(dāng)存儲(chǔ)芯片每個(gè)單元的字長(zhǎng)小于所需內(nèi)存單元字長(zhǎng)時(shí),需要用多個(gè)芯片構(gòu)成滿足字長(zhǎng)要求的存儲(chǔ)模塊,這就是位擴(kuò)展。( 3)用戶在市場(chǎng)上購(gòu)買內(nèi)存條進(jìn)行內(nèi)存擴(kuò)充,所做的是字?jǐn)U展的工作。5.10 74LS138譯碼器的接線圖如教材第245頁(yè)的圖5-47所示,試判斷其輸出端Y 0#、Y3#、Y
35、5#和Y7 #所決定的內(nèi)存地址范圍。解:因?yàn)槭遣糠值刂纷g碼(A17 不參加譯碼),故每個(gè)譯碼輸出對(duì)應(yīng)2 個(gè)地址范圍:Y 0# : 00000H 01FFFH 和 20000H 21FFFHY 3# : 06000H 07FFFH 和 26000H 27FFFHY 5# : 0A000H 0BFFFH和 2A000H 2BFFFHY 7#: 0E000H 0FFFFH和 2E000H 2FFFFH5.11 某 8088系統(tǒng)用2764 ROM 芯片和 6264 SRAM 芯片構(gòu)成16KB 的內(nèi)存。其中,ROM的地址范圍為 0FE000H0FFFFFH, RAM的地址范圍為 0F0000H0F1FF
36、FH。試?yán)?4LS138譯碼,畫出存儲(chǔ)器與CPU的連接圖,并標(biāo)出總線信號(hào)名稱。解:連接如下圖所示。5.12 敘述 EPROM 的編程過程,并說明EPROM 和 EEPROM 的不同點(diǎn)。(不要求)解:(1)對(duì)EPROM芯片的編程過程詳見教材第 215217頁(yè)。(2) EPROMS EEPROM勺不同之處為:。EPROM用紫外線擦除,EEPROMffl電擦除。EPROM是整片才S除,EEPROM可以整片擦除,也可以逐個(gè)字節(jié)地擦除。5.13試說明FLASH EEPROM芯片的特點(diǎn)及28F040的編程過程。(不要求)解:(1)特點(diǎn)是:它結(jié)合了 RAM和ROM的優(yōu)點(diǎn),讀寫速度接近于 RAM,斷電后信息
37、又不會(huì)丟失。(2) 28F040的編程過程詳見教材第 222223頁(yè)。第 6 章輸入輸出和中斷技術(shù)6.3 主機(jī)與外部設(shè)備進(jìn)行數(shù)據(jù)傳送時(shí),采用哪一種傳送方式,CPU 的效率最高?(不要求)解:使用DMA 傳送方式CPU 的效率最高。這是由DMA 的工作性質(zhì)所決定的。6.5 某輸入接口的地址為0E54H, 輸出接口的地址為01FBH, 分別利用74LS244和74LS273作為輸入和輸出接口。試編寫程序,使當(dāng)輸入接口的bit1、bit4和bit7 位同時(shí)為1時(shí),CPU將內(nèi)存中DATA為首址的20個(gè)單元的數(shù)據(jù)從輸出接口輸出; 若不滿足上述條件則等待。解: 首先判斷由輸入接口讀入數(shù)據(jù)的狀態(tài),若滿足條件
38、,則通過輸出接口輸出一個(gè)單元的數(shù)據(jù);之后再判斷狀態(tài)是否滿足,直到20 個(gè)單元的數(shù)據(jù)都從輸出接口輸出。LEA SI,DATA ; 取數(shù)據(jù)偏移地址MOV CL,20 ; 數(shù)據(jù)長(zhǎng)度送CLAGAIN: MOV DX,0E54HWAITT: IN AL,DX ; 讀入狀態(tài)值A(chǔ)ND AL,92H ;屏蔽掉不相關(guān)位,僅保留 bit1、bit4和bit7位狀態(tài)CMP AL,92H ;判斷bitl、bit4和bit7位是否全為1JNZ WAITT ; 不滿足 bit1、 bit4 和 bit7 位同時(shí)為1 則等待MOV DX,01FBHMOV AL,SIOUT DX,AL ; 滿足條件則輸出一個(gè)單元數(shù)據(jù)INC
39、SI ;修改地址指針LOOP AGAIN ; 若 20個(gè)單元數(shù)據(jù)未傳送完則循環(huán)6.14單片8259A能夠管理多少級(jí)可屏蔽中斷?若用 3片級(jí)聯(lián)能管理多少級(jí)可屏蔽中斷?(不要求)解:因?yàn)?259A 有 8 位可屏蔽中斷請(qǐng)求輸入端,故單片8259A 能夠管理8 級(jí)可屏蔽中斷。若用3 片級(jí)聯(lián),即1 片用作主控芯片,兩片作為從屬芯片,每一片從屬芯片可管理8 級(jí),則 3 片級(jí)聯(lián)共可管理22 級(jí)可屏蔽中斷。6.17 已知(SP) =0100H, (SS) =3500H, (CS) =9000H, (IP) =0200H, (00020H) =7FH, (00021H) = 1AH , (00022H) =
40、07H, (00023H) =6CH,在地址為90200H 開始的連續(xù)兩個(gè)單元中存放一條兩字節(jié)指令 INT 8。試指出在執(zhí)行該指令并進(jìn)入相應(yīng)的中斷例程時(shí),SP、 SS、 IP、 CS 寄存器的內(nèi)容以及SP 所指向的字單元的內(nèi)容是什么?解: CPU 在響應(yīng)中斷請(qǐng)求時(shí)首先要進(jìn)行斷點(diǎn)保護(hù),即要依次將FLAGS 和 INT 下一條指令的CS、IP寄存器內(nèi)容壓入堆棧,亦即棧頂指針減6,而SS的內(nèi)容不變。INT 8指令是一條兩字節(jié)指令,故其下一條指令的IP = 0200H+ 2=0202H。中斷服務(wù)子程序的入口地址則存放在中斷向量表(8X4)所指向白連續(xù)4個(gè)單元中。 所以, 在執(zhí)行中斷指令并進(jìn)入響應(yīng)的中斷
41、例程時(shí),以上各寄存器的內(nèi)容分別為:SP= 0100H 6=00FAHSS= 3500HIP=8X4 = 1A7FHCS=(8 X 4) + 2= 6C07HSP = 0200H +2 = 0202H第 7 章常用數(shù)字接口電路7.10 某8255芯片的地址范圍為 A380HA383H ,工作于方式0, A 口、B 口為 輸出口,現(xiàn)欲將PC4置0”,PC7置1”,試編寫初始化程序。解:該 8255 芯片的初始化程序包括置方式控制字及C 口的按位操作控制字。程序如下:MOV DX , 0A383H ;內(nèi)部控制寄存器地址送DXMOV AL , 80H ;方式控制字OUT DX, ALMOV AL , 08H ; P
溫馨提示
- 1. 本站所有資源如無(wú)特殊說明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請(qǐng)下載最新的WinRAR軟件解壓。
- 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請(qǐng)聯(lián)系上傳者。文件的所有權(quán)益歸上傳用戶所有。
- 3. 本站RAR壓縮包中若帶圖紙,網(wǎng)頁(yè)內(nèi)容里面會(huì)有圖紙預(yù)覽,若沒有圖紙預(yù)覽就沒有圖紙。
- 4. 未經(jīng)權(quán)益所有人同意不得將文件中的內(nèi)容挪作商業(yè)或盈利用途。
- 5. 人人文庫(kù)網(wǎng)僅提供信息存儲(chǔ)空間,僅對(duì)用戶上傳內(nèi)容的表現(xiàn)方式做保護(hù)處理,對(duì)用戶上傳分享的文檔內(nèi)容本身不做任何修改或編輯,并不能對(duì)任何下載內(nèi)容負(fù)責(zé)。
- 6. 下載文件中如有侵權(quán)或不適當(dāng)內(nèi)容,請(qǐng)與我們聯(lián)系,我們立即糾正。
- 7. 本站不保證下載資源的準(zhǔn)確性、安全性和完整性, 同時(shí)也不承擔(dān)用戶因使用這些下載資源對(duì)自己和他人造成任何形式的傷害或損失。
最新文檔
- 智慧農(nóng)業(yè)技術(shù)推廣實(shí)戰(zhàn)手冊(cè)
- 浙江廣告字施工方案
- 2025年人力資源制度:人事勞動(dòng)合同管理程序
- 定向井技術(shù)服務(wù)合同
- 設(shè)計(jì)和施工方案資質(zhì)
- 防彈玻璃施工方案
- 戶內(nèi)沉箱滲水施工方案
- TACCEM 129-2024 糧食環(huán)鏈刮板輸送機(jī)
- 鐵路伸縮縫圖片施工方案
- 威海鋁鎂錳屋面施工方案
- 水泥企業(yè)化驗(yàn)室控制組試題(庫(kù))
- 肇慶市勞動(dòng)合同
- 電力施工安全技術(shù)交底記錄表
- E4A使用手冊(cè)(DOC)
- (民法典版)離婚登記申請(qǐng)受理回執(zhí)單
- 食品質(zhì)量控制管理方案
- ISO9001_2016年[全套]質(zhì)量管理體系文件
- 普通中專畢業(yè)生登記表格模板(共4頁(yè))
- 電子病歷及病歷信息標(biāo)準(zhǔn)化(第五講)
- 鐵路建設(shè)項(xiàng)目工程試驗(yàn)室管理標(biāo)準(zhǔn)TB104422009
- SPSS術(shù)語(yǔ)中英文對(duì)照詳解
評(píng)論
0/150
提交評(píng)論