《微型計(jì)算機(jī)原理與接口技術(shù)》清華大學(xué)出版社-馮博琴-吳寧主編-課后答案

上傳人:簡(jiǎn)****9 文檔編號(hào):24886903 上傳時(shí)間:2021-07-15 格式:DOCX 頁(yè)數(shù):14 大小:31.82KB
收藏 版權(quán)申訴 舉報(bào) 下載
《微型計(jì)算機(jī)原理與接口技術(shù)》清華大學(xué)出版社-馮博琴-吳寧主編-課后答案_第1頁(yè)
第1頁(yè) / 共14頁(yè)
《微型計(jì)算機(jī)原理與接口技術(shù)》清華大學(xué)出版社-馮博琴-吳寧主編-課后答案_第2頁(yè)
第2頁(yè) / 共14頁(yè)
《微型計(jì)算機(jī)原理與接口技術(shù)》清華大學(xué)出版社-馮博琴-吳寧主編-課后答案_第3頁(yè)
第3頁(yè) / 共14頁(yè)

下載文檔到電腦,查找使用更方便

10 積分

下載資源

還剩頁(yè)未讀,繼續(xù)閱讀

資源描述:

《《微型計(jì)算機(jī)原理與接口技術(shù)》清華大學(xué)出版社-馮博琴-吳寧主編-課后答案》由會(huì)員分享,可在線閱讀,更多相關(guān)《《微型計(jì)算機(jī)原理與接口技術(shù)》清華大學(xué)出版社-馮博琴-吳寧主編-課后答案(14頁(yè)珍藏版)》請(qǐng)?jiān)谘b配圖網(wǎng)上搜索。

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ī)器碼,原來(lái)的數(shù)值叫做機(jī)器數(shù)的真值。 1.3 完成下列數(shù)制的轉(zhuǎn)換。 微型計(jì)算機(jī)的基本工作原理 匯編語(yǔ)言程序設(shè)計(jì) 微型計(jì)算機(jī)接口技術(shù) 建立微型計(jì)算機(jī)系統(tǒng)的整體概念,形成微機(jī)系統(tǒng)軟硬件開(kāi)發(fā)的初步能力。 解: ( 1) 166, A6H ( 2) 0.75 ( 3) 11111101.01B, FD.4H (4 ) 5B.AH, (10010001.1)BCD 1.4 8位和 16位二進(jìn)制數(shù)的原

2、碼、補(bǔ)碼和反碼可表示的數(shù)的范圍分別是多少? 解: 原碼( -127~+127)、( -32767~+32767) 補(bǔ)碼 (-128~+127)、( -32768~+32767) 反碼( -127~+127)、( -32767~+32767) 1.5 寫(xiě)出下列真值對(duì)應(yīng)的原碼和補(bǔ)碼的形式。 ( 1) X= -1110011B ( 2) X= -71D ( 3) X= +1001001B 解: ( 1)原碼: 11110011 補(bǔ)碼: 10001101 ( 2)原碼: 11000111 補(bǔ)碼: 10111001 ( 3)原碼: 01001001 補(bǔ)碼: 01001001 1

3、.6 寫(xiě)出符號(hào)數(shù) 10110101B 的反碼和補(bǔ)碼。 解:, 11001011 1.7 已知 X 和 Y 的真值,求 [X+Y] 的補(bǔ)碼。 ( 1) X=-1110111B Y=+1011010B ( 2) X=56D Y= -21D 解: 1) 11100011 2) 2) 00100011 1.8 已知 X= -1101001B, Y= -1010110B ,用補(bǔ)碼求 X-Y 的值。 解: 11101101 1.9 請(qǐng)寫(xiě)出下列字符的 ASCII 碼。 4A3- ! 解: 34H, 41H , 33H, 3DH , 21H 1.10 若給字符 4 和 9 的 A

4、SCII 碼加奇校驗(yàn),應(yīng)是多少? 解: 34H, B9H 1.11 上題中若加偶校驗(yàn),結(jié)果如何? 解: B4H, 39H 1.12 計(jì)算下列表達(dá)式。 1) (4EH+10110101B) x (0.0101) BCD= ( ) D 2) 2) 4EH-( 24/08H+ ’B ’/2) = ( ) B 解: 1) 129.5D 2) 2) 101010B 第 2 章微型計(jì)算機(jī)基礎(chǔ) 2.6 簡(jiǎn)述CPU執(zhí)行程序的過(guò)程。 解:當(dāng)程序的第一條指令所在的地址送入程序計(jì)數(shù)器后, CPU 就進(jìn)入取指階段 準(zhǔn)備取第一條指令。在取指階段, CPU 從內(nèi)存中讀出指令,并把指令送至

5、指令 寄存器 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 說(shuō)明 8086 的 EU 和 BIU 的主要功能。 在執(zhí)行程序過(guò)程中他們是如何相互配合 工作的? 解: 執(zhí)行單元 EU 負(fù)責(zé)執(zhí)行指令。 EU 在工作時(shí)不斷地從指令隊(duì)列取出指令代碼, 對(duì)其譯碼后產(chǎn)生完成指令所需要的控制信息。數(shù)據(jù)在 ALU 中進(jìn)行運(yùn)算,運(yùn)算結(jié) 果的特征保留在標(biāo)志寄存器 FLAGS 中。

6、 總線接口單元 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 根據(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ā)出訪問(wèn)總

7、線的請(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í)行指令期間 ,BIU 能直接訪問(wèn)存儲(chǔ)器嗎 ?為什么 ? 解 :可以 .因?yàn)?EU 和 BIU 可以并行工作 ,EU 需要的指令可以從指令隊(duì)列中獲得 ,這 時(shí) BIU 預(yù)先從存儲(chǔ)器中取出并

8、放入指令隊(duì)列的。 在 EU 執(zhí)行指令的同時(shí), BIU 可 以訪問(wèn)存儲(chǔ)器取下一條指令或指令執(zhí)行時(shí)需要的數(shù)據(jù)。 2.9 8086與 8088CPU 的主要區(qū)別有哪些? 解:主要區(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)橹挥?8 位 ,所以每個(gè)總線周期只能存取 1 個(gè)字節(jié) . ④個(gè)別引腳信號(hào)的含義稍有不同 . 2.10

9、 8088CPU工作在最小模式下: ( 1)當(dāng) CPU 訪問(wèn)存儲(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 以及 AD0~AD7 、 A8~A19。 ( 2)同( 1)。 ( 3)所有三態(tài)輸出的地址信號(hào)、數(shù)據(jù)信號(hào)和控制信號(hào)均置為高阻態(tài)。 2.11 總線周期中,什么情況下要插入 TW 等待周期?插入 TW 周期的個(gè)數(shù),取 決于什么因素? 解:在每個(gè)總線周期的 T3 的開(kāi)始處若 READY

10、 為低電平,則 CPU 在 T3 后插入 一個(gè)等待周期TW。在TW的開(kāi)始時(shí)刻,CPU還要檢查READY狀態(tài),若仍為低 電平, 則再插入一個(gè) TW 。 此過(guò)程一直進(jìn)行到某個(gè) TW 開(kāi)始時(shí), READY 已經(jīng)變 為高電平,這時(shí)下一個(gè)時(shí)鐘周期才轉(zhuǎn)入 T4。 可以看出,插入 TW 周期的個(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)分別 表示什么含義? 解:(略),見(jiàn)書(shū)第 49 頁(yè)。

11、 2.14 8086/8088 CPU中,有哪些通用寄存器和專用寄存器?說(shuō)明它們的作用。 解:通用寄存器包含以下 8 個(gè)寄存器: AX 、 BX 、 CX 和 DX 寄存器一般用于存放參與運(yùn)算的數(shù)據(jù)或運(yùn)算的結(jié)果。除此 之外: AX :主要存放算術(shù)邏輯運(yùn)算中的操作數(shù),以及存放 I/O 操作的數(shù)據(jù)。 BX:存放訪問(wèn)內(nèi)存時(shí)的基地址。 CX:在循環(huán)和用操作指令中用作計(jì)數(shù)器。 DX :在寄存器間接尋址的 I/O 指令中存放 I/O 地址。在做雙字長(zhǎng)乘除法運(yùn)算時(shí), DX 與 AX 合起來(lái)存放一個(gè)雙字長(zhǎng)數(shù)。 SP:存放棧頂偏移地址。 BP:存放訪問(wèn)內(nèi)存時(shí)的基地址。 SP和BP也可以存

12、放數(shù)據(jù),但它們的默認(rèn)段寄存器都是 SS。 SI:常在變址尋址方式中作為源地址指針。 DI :常在變址尋址方式中作為目標(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é)?最小 為多少

13、個(gè)字節(jié)? 解:分段的主要目的是便于存儲(chǔ)器的管理,使得可以用 16 位寄存器來(lái)尋址 20 位的內(nèi)存空間。一個(gè)段最大為 64KB ,最小為 16B。 2.16 在 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ǔ)器物理地

14、址為 78A00H, 計(jì)算出它所對(duì)應(yīng)的邏輯地址。 此結(jié)果惟一 嗎? 解:物理地址可以對(duì)應(yīng)于不同的邏輯地址。 78A00H 對(duì)應(yīng)的邏輯地址可以是 7000H: 8A00H, 7800H : 0A00H , 78A0H : 0000H 等。結(jié)果不是惟一的。 2.18 設(shè)當(dāng)前數(shù)據(jù)段位于存儲(chǔ)器的 A8000H~B7FFFH , DS段寄存器的內(nèi)容應(yīng)是什 么? 解:因?yàn)?A8000H 到 B7FFFH 之間的地址范圍大小為 64KB ,未超出一個(gè)段的最 大范圍。故要訪問(wèn)此地址范圍的數(shù)據(jù),數(shù)據(jù)段的起始地址(即段首地址)應(yīng)為 A8000H, WJ DS 段寄存器為 A800H。 2.19 若

15、CS=8000H,則當(dāng)前代碼段可尋址的存儲(chǔ)空間的范圍是多少? 解( CS) =8000H 時(shí),當(dāng)前代碼段可尋址的存儲(chǔ)空間范圍為 80000H~8FFFFH。 2.20 8086/8088 CPU 在最小模式下構(gòu)成計(jì)算機(jī)系統(tǒng)至少應(yīng)包括哪幾個(gè)基本部分 (器件)? 解:其至少應(yīng)包括: 8088CPU、 8284 時(shí)鐘發(fā)生器、 8282鎖存器( 3 片)和 8286 雙向總線驅(qū)動(dòng)器。 第 3 章 8088/8086 指令系統(tǒng) 3.1 什么叫尋址方式? 8086/8088CPU共有哪幾種尋址方式? 解:尋址方式主要是指獲得操作數(shù)所在地址的方法 .8086/8088CPU具有:立即尋 址

16、、直接尋址、寄存器尋址、寄存器間接尋址、寄存器相對(duì)尋址、基址一變址尋 址、基址一變址-相對(duì)尋址以及隱含尋址等 8 種尋址方式。 3.2 設(shè)(DS)=6000H, (ES)=2000H, (SS)=1500H, (Si) =00A0H, (BX)=0800H , (BP)=1200H,數(shù)據(jù)變量VAR為0050H.請(qǐng)分別指出下列各條指令源操作數(shù)的尋 址方式?它的物理地址是多少? (1) MOV AX,BX (2) MOV DL,80H (3) MOV AX, VAR (4) MOV AX,VAR[BX][SI] (5) MOV AL,B (6) MOV DI, ES: [BX] (7)

17、 MOV DX,[BP] (8) MOV BX , 20H[BX] 解: (1)寄存器尋址。因源操作數(shù)是寄存器,故寄存器 BX 就是操作數(shù)的地址 . (2)立即尋址。操作數(shù) 80H 存放于代碼段中指令碼 MOV 之后。 (3)直接尋址。 ( 4)基址一變址一相對(duì)尋址. 操作數(shù)的物理地址=(DS) X 16+(SI)+(BX) + VAR =60000H + 00A0H + 0800H + 0050H= 608F0H (5)立即尋址 (6)寄存器間接尋址 . 操作數(shù)的物理地址=(ES) X 16+(BX) = 20000H+ 0800H = 20800H (7)寄存器間接

18、尋址。 操作數(shù)的物理地址=(SS) X 16+(BP) = 15000H+ 1200H= 16200H (8)寄存器相對(duì)尋址. 操作數(shù)的物理地址=(DS) X 16+(BX)+20H = 60000H+ 0800H+ 20H= 60820H 3.3 假 設(shè) (DS)= 212AH,(CS)= 0200H,(IP)= 1200H,(BX)= 0500H, 位 移 量 DATA=40H , (217A0H) =2300H, (217E0H)=0400H, (217E2H) =9000H 試確定下列轉(zhuǎn)移指令的轉(zhuǎn)移地址 . (1) JMP 2300H (2) JMP WORD PTR[

19、BX] (3) JMP DWORD PTR[BX+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)容。 (1)段內(nèi)直接轉(zhuǎn)移。轉(zhuǎn)移的物理地址 二(CS) X 16 +2300H =02000H+2300H=04300H (2)段內(nèi)間接轉(zhuǎn)移。轉(zhuǎn)移的物理地址=(CS) X 16+ [BX] =(CS) X16+(21

20、7A0H) =02000H+2300H=04300H (3)段間間接轉(zhuǎn)移。轉(zhuǎn)移的物理地址 =[BX+DATA] =(217E2H) X16+(217E0H) =90000H+0400H=90400H 3.4 試說(shuō)明指令 MOV BX,5[BX] 與指令 LEA BX,5[BX] 的區(qū)別。 解:前者是數(shù)據(jù)傳送類指令,表示將數(shù)據(jù)段中以 (BX+5)為偏移地址的16位數(shù)據(jù) 送寄存器 BX. 后者是取偏移地址指令, 執(zhí)行的結(jié)果是 (BX ) = (BX) + 5, 即操作數(shù)的偏移地址為 (BX)+5。 3.5 設(shè)堆棧指針SP的初值為2300H,(AX) =50ABH ,(BX)=12

21、34H。執(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)=1234H 3.6 指出下列指令的錯(cuò)誤: (1) MOV AH , CX (2) MOV 33H , AL (3) MOV AX, [SI][DI] (4) MOV [BX] , [SI] (5) A

22、DD BYTE PTR[BP],256 (6) MOV DATA[SI],ES:AX (7) JMP BYTE PTR[BX] (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)

23、至少應(yīng)是 16 位的。 (8)指令錯(cuò)。對(duì)輸人輸出指令,當(dāng)端口地址超出 8 位二進(jìn)制數(shù)的表達(dá)范圍(即尋 址的端口超出 256 個(gè))時(shí),必須采用間接尋址。 (9)指令正確。 (10)指令錯(cuò)。 MUL 指令不允許操作數(shù)為立即數(shù)。 3.7 已知(AL) =7BH, (BL) =38H,試問(wèn)執(zhí)行指令 ADD AL, BL 后,AF、CF、OF、PF、 SF 和 ZF 的值各為多少? 解: AF=1 , CF=0, OF=1, PF=0, SF=l , ZF=0 3.8 試比較無(wú)條件轉(zhuǎn)移指令、條件轉(zhuǎn)移指令、調(diào)用指令和中斷指令有什么異同? 解: 無(wú)條件轉(zhuǎn)移指令的操作是無(wú)條件地使程序轉(zhuǎn)移到指

24、定的目標(biāo)地址, 并從該地 址開(kāi)始執(zhí)行新的程序段, 其轉(zhuǎn)移的目標(biāo)地址既可以是在當(dāng)前邏輯段, 也可以是在 不同的邏輯段;條件轉(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)用過(guò)程人口地址的位置可將調(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 (或

25、 CS 和 IP). 中斷指令是因一些突發(fā)事件而使 CPU 暫時(shí)中止它正在運(yùn)行的程序 ,轉(zhuǎn)去執(zhí)行一組 專門(mén)的中斷服務(wù)程序, 并在執(zhí)行完后返回原被中止處繼續(xù)執(zhí)行原程序。 它是隨機(jī) 的。在響應(yīng)中斷后 CPU 不僅要保護(hù)斷點(diǎn)(即 INT 指令下一條指令的段地址和偏 移地址),還要將標(biāo)志寄存器 FLAGS 壓入堆棧保存。 3.9 試判斷下列程序執(zhí)行后 ,BX 中的內(nèi)容. MOV CL, 3 MOV BX,0B7H ROL BX,1 ROR BX,CL 解:該程序段是首先將 BX 內(nèi)容不帶進(jìn)位循環(huán)左移 1 位,再循環(huán)右移 3位。即相 當(dāng)于將原 BX 內(nèi)容不帶進(jìn)位循環(huán)右移 2 位,

26、故結(jié)果為: (BX)=0C02DH 3.10 按下列要求寫(xiě)出相應(yīng)的指令或程序段。 (1)寫(xiě)出兩條使 AX 內(nèi)容為 0 的指令。 (2)使 BL 寄存器中的高 4 位和低 4 位互換。 (3)屏蔽CX寄存器的bll,b7和b3位。 (4)測(cè)試 DX 中的 b0 和 b8 位是否為 1。 解: (1) MOV AX,0 XOR AX,AX ;AX 寄存器自身相異或,可使其內(nèi)容清 0 (2) MOV CL, 4 ROL BL,CL ; 將 BL 內(nèi)容循環(huán)左移 4位,可實(shí)現(xiàn)其高 4位和低 4位 的互換 (3) AND CX,0F777H ;將 CX 寄存器中需屏蔽的位 “與

27、”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 CLD LEA SI,FIRST LEA DI, [1200H] LEA DI, SECOND MOV CX,0FOOH STD XOR AX,AX REP MOVSB REP STOSW 解: (1)該段程序的功能是: 將數(shù)據(jù)段中 FIRST 為最高地址的 10個(gè)字節(jié)

28、數(shù)據(jù)按減地址 方向傳送到附加段 SECOND 為最高地址的向前 10 個(gè)單元中。 (2)將附加段中偏移地址為 1200H 單元開(kāi)始的 0FOOH 個(gè)字單元清 0。 1.12 執(zhí)行以下兩條指令后,標(biāo)志寄存器 FLAGS 的六個(gè)狀態(tài)位各為什么狀態(tài)? MOV AX,84A0H ADD AX,9460H 解:執(zhí)行 ADD 指令后, 6 個(gè)狀態(tài)標(biāo)志位的狀態(tài)分別為: 在兩個(gè) 16 位數(shù)進(jìn)行加法運(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,

29、SF=0, OF=1。 1.13 將+46和-38 分別乘以 2,可應(yīng)用什么指令來(lái)完成?如果除以 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ù)乘法指令 IMUL 完成。 如果是除以2,則進(jìn)行相反操作,即用邏輯右移指令SHR或無(wú)符號(hào)數(shù)除法指令DIV 實(shí)現(xiàn) +46除以 2 的運(yùn)算, 用算術(shù)右移指令 SAR 或有符號(hào)數(shù)除法指令 IDIV 實(shí)現(xiàn)

30、-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é)果: (AL)=40H 。 (3) 將 AX=8060H 輸出到地址為 03F8H 的端口中。 (4)由

31、48H 端口讀人 16 位二進(jìn)制數(shù)。 (5)將 8060H 輸出到地址為 84H 的端口中。 第 4 章匯編語(yǔ)言程序設(shè)計(jì) 4.1 請(qǐng)分別用 DB 、 DW 、 DD 偽指令寫(xiě)出在 DATA 開(kāi)始的連續(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,88H DATA DW 2211H,4433H,6655H,8877H

32、 DATA DD 44332211H,88776655H 4.2 若程序的數(shù)據(jù)段定義如下 ,寫(xiě)出各指令語(yǔ)句獨(dú)立執(zhí)行后的結(jié)果 : DSEG SEGMENT DATA1 DB 10H,20H,30H DATA2 DW 10 DUP(?) STRING DB ‘123’ DSEG ENDS (1) MOV AL,DATA1 (2) MOV BX,OFFSET DATA2 (3) LEA SI,STRING ADD DI,SI 解: 取變量 DATA1 的值 . 指令執(zhí)行后 ,(AL)=10H. 變量 DATA2 的偏移地址 . 指令執(zhí)行后 ,(BX)=0003H. (3)

33、先取變量STRING的偏移地址送寄存器SI,之后送SI的內(nèi)容與DI的內(nèi)容相加 并將結(jié)果送 DI.指令執(zhí)行后,(SI)=0017H;(DI)=(DI)+0017H. 4.3 試編寫(xiě)求兩個(gè)無(wú)符號(hào)雙子長(zhǎng)數(shù)之和的程序 . 兩數(shù)分別在 MEM1 和 MEM2 單 元中 ,和放在 SUM 單元 . 解: DSEG SEGMENT MEM1 DW 1122H,3344H MEM2 DW 5566H,7788H SUM DW 2 DUP(?) DSEG ENDS CSEG SEGMENT ASSUME CS:CSEG,DS:DSEG START: MOV AX,DSEG MOV DS,

34、AX LEA BX,MEM1 LEA SI,MEM2 LEA DI,SUM MOV CL,2 CLC AGAIN: MOV AX,[BX] ADC AX,[SI] MOV [DI],AX ADD BX,2 ADD SI,2 ADD DI,2 LOOP AGAIN HLT CSEG ENDS END START 4.4 試編寫(xiě)程序,測(cè)試AL寄存器的第4位(bit4)是否為0? 解 : 測(cè)試寄存器 AL 中某一位是否為 0,可使用 TEST 指令、 AND 指令、 移位指令 等幾種方法實(shí)現(xiàn)。 如: TEST AL , 10H JZ NEXT NEXT:…

35、 或者: MOV CL , 4 SHL AL , CL JNC NEXT . NEXT:… 4.7 執(zhí)行下列指令后, AX 寄存器的內(nèi)容是多少? TABLE DW 10 , 20, 30, 40, 50 ENTRY DW 3 MOV BX , OFFSET TABLE ADD BX , ENTRY MOV AX , [BX] 解:( AX) =1E00H 4.12 畫(huà)圖說(shuō)明下列語(yǔ)句分配的存儲(chǔ)空間及初始化的數(shù)據(jù)值。 1) DATA1 DB ‘BYTE ’, 12, 12H, 2 DUP(0,?, 3) 2) 2) DATA2 DW 4 DUP ( 0, 1, 2)

36、,?, -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í)只能讀出,不能寫(xiě)入。 RAM則可讀可寫(xiě)。 斷電后,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ū)的容

37、量位 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 根用于片選譯碼。 注意,用于片內(nèi)尋址的 16 根地址線要通過(guò)二選一多路器連到 2164 芯片,因?yàn)? 2164芯片是DRAM,高位地址與低位地址是分時(shí)傳送的。 5.9 甚什么是字?jǐn)U展?什么是位擴(kuò)展?用戶自己購(gòu)買內(nèi)存條進(jìn)行內(nèi)存擴(kuò)充, 是在 進(jìn)行何種

38、存儲(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所示,試判斷其輸出端 Y0#、Y3#、Y5#和Y7 #所決定的內(nèi)存地址范圍。 解:因?yàn)槭遣糠值刂纷g碼( A17 不參加譯碼),故每個(gè)譯碼輸出對(duì)應(yīng) 2 個(gè)地址范 圍: Y0# : 00000H ?01FFFH

39、 和 20000H ?21FFFH Y3# : 06000H ?07FFFH 和 26000H ?27FFFH Y5# : 0A000H ?0BFFFH和 2A000H ?2BFFFH Y7#: 0E000H ?0FFFFH和 2E000H ?2FFFFH 5.11 某 8088系統(tǒng)用 2764 ROM 芯片和 6264 SRAM 芯片構(gòu)成 16KB 的內(nèi)存。其 中,ROM的地址范圍為 0FE000H?0FFFFFH, RAM的地址范圍為 0F0000H? 0F1FFFH。試?yán)?4LS138譯碼,畫(huà)出存儲(chǔ)器與CPU的連接圖,并標(biāo)出總線信 號(hào)名稱。 解:連接如下圖所示。 5.1

40、2 敘述 EPROM 的編程過(guò)程,并說(shuō)明 EPROM 和 EEPROM 的不同點(diǎn)。(不要 求) 解: (1)對(duì)EPROM芯片的編程過(guò)程詳見(jiàn)教材第 215?217頁(yè)。 (2) EPROMS EEPROM勺不同之處為: 。EPROM用紫外線擦除,EEPROMffl電擦除。 。EPROM是整片才S除,EEPROM可以整片擦除,也可以逐個(gè)字節(jié)地擦除。 5.13試說(shuō)明FLASH EEPROM芯片的特點(diǎn)及28F040的編程過(guò)程。(不要求) 解: (1)特點(diǎn)是:它結(jié)合了 RAM和ROM的優(yōu)點(diǎn),讀寫(xiě)速度接近于 RAM,斷電后信 息又不會(huì)丟失。 (2) 28F040的編程過(guò)程詳見(jiàn)教材第 222

41、?223頁(yè)。 第 6 章輸入輸出和中斷技術(shù) 。 6.3 主機(jī)與外部設(shè)備進(jìn)行數(shù)據(jù)傳送時(shí), 采用哪一種傳送方式, CPU 的效率最高? (不要求) 解:使用 DMA 傳送方式 CPU 的效率最高。這是由 DMA 的工作性質(zhì)所決定的。 6.5 某輸入接口的地址為 0E54H, 輸出接口的地址為 01FBH , 分別利用 74LS244 和74LS273作為輸入和輸出接口。試編寫(xiě)程序,使當(dāng)輸入接口的bit1、bit4和bit7 位同時(shí)為1時(shí),CPU將內(nèi)存中DATA為首址的20個(gè)單元的數(shù)據(jù)從輸出接口輸出; 若不滿足上述條件則等待。 解: 首先判斷由輸入接口讀入數(shù)據(jù)的狀態(tài), 若滿足條件, 則

42、通過(guò)輸出接口輸出一 個(gè)單元的數(shù)據(jù);之后再判斷狀態(tài)是否滿足,直到 20 個(gè)單元的數(shù)據(jù)都從輸出接口 輸出。 LEA SI,DATA ; 取數(shù)據(jù)偏移地址 MOV CL,20 ; 數(shù)據(jù)長(zhǎng)度送 CL AGAIN: MOV DX,0E54H WAITT: IN AL,DX ; 讀入狀態(tài)值 AND AL,92H ;屏蔽掉不相關(guān)位,僅保留 bit1、bit4和bit7位狀態(tài) CMP AL,92H ;判斷bit1、bit4和bit7位是否全為1 JNZ WAITT ; 不滿足 bit1、 bit4 和 bit7 位同時(shí)為 1 則等待 MOV DX,01FBH MOV AL,[SI] OU

43、T DX,AL ; 滿足條件則輸出一個(gè)單元數(shù)據(jù) INC SI ;修改地址指針 LOOP AGAIN ; 若 20個(gè)單元數(shù)據(jù)未傳送完則循環(huán) 6.14 單片 8259A 能夠管理多少級(jí)可屏蔽中斷?若用 3 片級(jí)聯(lián)能管理多少級(jí)可屏 蔽中斷?(不要求) 解:因?yàn)?8259A 有 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, (I

44、P) =0200H, (00020H) =7FH, (00021H) = 1AH , (00022H) = 07H, (00023H) =6CH, 在地址為 90200H 開(kāi)始的連續(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é)指令,故其下一條指令

45、的 IP = 0200H+ 2=0202H。 中斷服務(wù)子程序的入口地址則存放在中斷向量表 (8X4)所指向白^連續(xù)4個(gè)單元 中。 所以, 在執(zhí)行中斷指令并進(jìn)入響應(yīng)的中斷例程時(shí), 以上各寄存器的內(nèi)容分別 為: SP= 0100H— 6=00FAH SS= 3500H IP=[8X4] = 1A7FH CS=[(8 X 4) + 2]= 6C07H [SP] = 0200H +2 = 0202H 第 7 章常用數(shù)字接口電路 7.10 某8255芯片的地址范圍為 A380H?A383H ,工作于方式0, A 口、B 口為 輸出口,現(xiàn)欲將PC4置0”,PC7置1”,試編寫(xiě)初始化程

46、序。 解:該 8255 芯片的初始化程序包括置方式控制字及 C 口的按位操作控制字。程 序如下: MOV DX , 0A383H ;內(nèi)部控制寄存器地址送 DX MOV AL , 80H ;方式控制字 OUT DX , AL MOV AL , 08H ; PC4 置 0 OUT DX , AL MOV AL , 0FH ; PC7 置 1 OUT DX , AL 7.11 設(shè)8255芯片的接口地址范圍為 03F8H?03FBH, A 組B組均工作于方式 0, A 口作為數(shù)據(jù)輸出口, C 口低 4 位作為控制信號(hào)輸入口,其他端口未使用。 試畫(huà)出該片 8255 芯片與系統(tǒng)的電

47、路連接圖,并編寫(xiě)初始化程序。 解: 8255芯片與系統(tǒng)的電路連接如圖所示。 由題目知,不需對(duì) C 口置位控制字,只需對(duì) 8255 置方式控制字,故其初始化 程序如下: MOV DX , 03FBH MOV AL , 81H OUT DX , AL 7.12 已知某 8088微機(jī)系統(tǒng)的 I/0 接口電路框圖如教材中圖 7-47所示。試完成: ( 1)根據(jù)圖中接線,寫(xiě)出 8255 芯片、 8253芯片各端口的地址。 ( 2)編寫(xiě) 8255 芯片和 8253 芯片的初始化程序。其中, 8253 芯片的 OUT 1 端 輸出 100Hz 方波, 8255芯片的 A 口為輸出, B 口

48、和 C 口為輸入。 ( 3)為 8255 芯片編寫(xiě)一個(gè) I/O 控制子程序,其功能為:每調(diào)用一次,先檢測(cè) PC0的狀態(tài),若PC0 = 0,則循環(huán)等待;若PC0 = 1,可從PB 口讀取當(dāng)前開(kāi)關(guān) K 的位置(0?7 ),經(jīng)轉(zhuǎn)換計(jì)算從 A 口的PA0?PA3輸出該位置的二進(jìn)制編碼, 供 LED 顯示。 解: ( 1) 8255芯片的地址范圍為:8000H?FFFFH 8253芯片的地址范圍為:0000H?7FFFH ( 2) ;初始化 8255 芯片 MOV DX , 8003H MOV AL , 8BH ;方式控制字,方式 0, A 口輸出, B 口和 C 口輸入 OUT D

49、X , AL ;初始化 8253 MOV DX , 0003H ;內(nèi)部寄存器口地址 MOV AL , 76H ;計(jì)數(shù)器 1,先寫(xiě)低 8 位/后寫(xiě)高 8 位,方式 3,二進(jìn)制計(jì)數(shù) OUT DX , AL MOV DX , 0001H ;計(jì)數(shù)器 1 端口地址 MOV AX , 10000 ;設(shè)計(jì)數(shù)初值 =10000 OUT DX , AL MOV AL , AH OUT DX , AL ( 3) ; 8255芯片的控制子程序 ;定義顯示開(kāi)關(guān)位置的字形譯碼數(shù)據(jù) DATA SEGMENT BUFFER DB 3FH , 06H , 5BH, 0FH, 66H, 6DH ,

50、7CH, 07H DATA ENDS CODE SEGMENT ASSUME CS : CODE, DS: DATA MAIN PROC PUSH DS MOV AX , DATA MOV DS , AX CALL DISP POP DX RET MAIN ENDP ;輸出開(kāi)關(guān)位置的二進(jìn)制碼程序 DISP PROC PUSH CX PUSH SI XOR CX , CX CLC LEA SI, BUFFER MOV DX , 8002H ; C 口地址 WAITT : IN AL , DX ; C 口狀態(tài) TEST AL , 01H JZ WAITT MOV DX , 8001H ;讀 B 口的開(kāi)關(guān)位置 IN AL , DX NEXT : SHR AL , 1 INC CX JC NEXT ;沒(méi)有接地則移動(dòng) DEC CX ADD SI , CX ;查表, CX 為開(kāi)關(guān)位置 MOV AL , [SI] MOV DX , 8000H OUT DX , AL ; POP SI POP CX RET DISP ENDP CODE ENDS END MAIN

展開(kāi)閱讀全文
溫馨提示:
1: 本站所有資源如無(wú)特殊說(shuō)明,都需要本地電腦安裝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ù)覽,若沒(méi)有圖紙預(yù)覽就沒(méi)有圖紙。
4. 未經(jīng)權(quán)益所有人同意不得將文件中的內(nèi)容挪作商業(yè)或盈利用途。
5. 裝配圖網(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ì)自己和他人造成任何形式的傷害或損失。

最新文檔

相關(guān)資源

更多
正為您匹配相似的精品文檔
關(guān)于我們 - 網(wǎng)站聲明 - 網(wǎng)站地圖 - 資源地圖 - 友情鏈接 - 網(wǎng)站客服 - 聯(lián)系我們

copyright@ 2023-2025  zhuangpeitu.com 裝配圖網(wǎng)版權(quán)所有   聯(lián)系電話:18123376007

備案號(hào):ICP2024067431號(hào)-1 川公網(wǎng)安備51140202000466號(hào)


本站為文檔C2C交易模式,即用戶上傳的文檔直接被用戶下載,本站只是中間服務(wù)平臺(tái),本站所有文檔下載所得的收益歸上傳人(含作者)所有。裝配圖網(wǎng)僅提供信息存儲(chǔ)空間,僅對(duì)用戶上傳內(nèi)容的表現(xiàn)方式做保護(hù)處理,對(duì)上載內(nèi)容本身不做任何修改或編輯。若文檔所含內(nèi)容侵犯了您的版權(quán)或隱私,請(qǐng)立即通知裝配圖網(wǎng),我們立即給予刪除!