![微機(jī)原理答案-南京理工大學(xué)_第1頁](http://file3.renrendoc.com/fileroot_temp3/2022-2/17/5fef3b79-b3b8-411a-9192-b4d7df997045/5fef3b79-b3b8-411a-9192-b4d7df9970451.gif)
![微機(jī)原理答案-南京理工大學(xué)_第2頁](http://file3.renrendoc.com/fileroot_temp3/2022-2/17/5fef3b79-b3b8-411a-9192-b4d7df997045/5fef3b79-b3b8-411a-9192-b4d7df9970452.gif)
![微機(jī)原理答案-南京理工大學(xué)_第3頁](http://file3.renrendoc.com/fileroot_temp3/2022-2/17/5fef3b79-b3b8-411a-9192-b4d7df997045/5fef3b79-b3b8-411a-9192-b4d7df9970453.gif)
版權(quán)說明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請進(jìn)行舉報(bào)或認(rèn)領(lǐng)
文檔簡介
1、目錄CH01 微型電腦概述 1CH02 8086 8088 指令系統(tǒng) 6CH03 匯編語言程序設(shè)計(jì) 12CH04 存儲系統(tǒng) 27CH05 定時(shí)與計(jì)數(shù) 31CH06 輸入輸出控制 35CH01 微型電腦概述1 微型電腦由哪些部件組成?各部件的主要功能是什么?解答:微機(jī)系統(tǒng)微型電腦系統(tǒng)軟件外圍設(shè)備:打印機(jī)、鍵盤、CRT、磁盤控制器等微處理器CPU系統(tǒng)總線: AB 、 CB 、 DB功能:為 CPU 和其他部件之間提供數(shù)據(jù)、地址和控制信息的傳輸通道存儲器:只讀存儲器ROM、隨機(jī)存儲器RAM功能:用來存儲信息輸入/輸出I/O丨接口:串/并行接口等功能:使外部設(shè)備和微型機(jī)相連算術(shù)邏輯部件 (ALU 累加
2、器、寄存器控制器操作系統(tǒng) OS 系統(tǒng)實(shí)用程序:匯編、編譯、編輯、調(diào)試程序等注: CPU 的功能可以進(jìn)行算術(shù)和邏輯運(yùn)算; 可保存少量數(shù)據(jù); 能對指令進(jìn)行譯碼并執(zhí)行規(guī)定的動作; 能和存儲器、外設(shè)交換數(shù)據(jù); 提供整修系統(tǒng)所需要的定時(shí)和控制; 可以響應(yīng)其他部件發(fā)來的中斷請示。 2 8086/8088 CPU 由哪兩部分組成?它們的主要功能各是什么?是如何協(xié)調(diào)工作的? 解答:微處理器 CPU : 總線接口部件 (BIU :負(fù)責(zé)與存儲器、 I/O 端口傳送數(shù)據(jù)執(zhí)行部件EU:負(fù)責(zé)指令的執(zhí)行協(xié)調(diào)工作過程: 總線接口部件和執(zhí)行部件并不是同步工作的,它們按以下流水線技術(shù)原則來協(xié)調(diào)管理: 每當(dāng) 8086 的指令隊(duì)列
3、中有兩個(gè)空字節(jié), 或者 8088 的指令隊(duì)列中有一個(gè)空字節(jié)時(shí), 總線 接口部件就會自動把指令取到指令隊(duì)列中。 每當(dāng)執(zhí)行部件準(zhǔn)備執(zhí)行一條指令時(shí),它會從總線接口部件的指令隊(duì)列前部取出指令的代碼, 然后用幾個(gè)時(shí)鐘周期去執(zhí)行指令。 在執(zhí)行指令的過程中, 如果必須訪問存儲器或者 輸入 /輸出設(shè)備,那么,執(zhí)行部件就會請求總線接口部件進(jìn)入總線周期,完成訪問內(nèi)存或者 輸入 /輸出端口的操作;如果此時(shí)總線接口部件正好處于空閑狀態(tài),那么,會立即響應(yīng)執(zhí)行 部件的總線請求。 但有時(shí)會遇到這樣的情況, 執(zhí)行部件請求總線接口部件訪問總線時(shí), 總線 接口部件正在將某個(gè)指令字節(jié)取到指令隊(duì)列中, 此時(shí)總線接口部件將首先完成這個(gè)
4、取指令的 操作,然后再去響應(yīng)執(zhí)行部件發(fā)出的訪問總線的請求。 當(dāng)指令隊(duì)列已滿, 而且執(zhí)行部件又沒有總線訪問請求時(shí), 總線接口部件便進(jìn)入空閑狀態(tài)。 在執(zhí)行轉(zhuǎn)移指令、調(diào)用指令和返回指令時(shí),由于程序執(zhí)行的順序發(fā)生了改變,不再是順 序執(zhí)行下面一條指令,這時(shí),指令隊(duì)列中已經(jīng)按順序裝入的字節(jié)就沒用了。遇到這種情況, 指令隊(duì)列中的原有內(nèi)容將被自動消除, 總線接口部件會按轉(zhuǎn)移位置往指令隊(duì)列裝入另一個(gè)程 序段中的指令。3 8086/8088 CPU 中有哪些寄存器?各有什么用途?標(biāo)志寄存器 F 有哪些標(biāo)志位?各在 什么情況下置位?解答:寄存器功能 數(shù)據(jù)寄存器AX 字乘法,字除法,字 I/OBX 查表轉(zhuǎn)換CX 串操
5、作,循環(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ū)標(biāo)志寄存器 F的標(biāo)志位:控制標(biāo)志:DF、IF、TF;狀態(tài)標(biāo)志:SF、ZF、AF、PF、 CF、 OF。標(biāo)志寄存器F的各標(biāo)志位置位情
6、況:CF:進(jìn)位標(biāo)志位。做加法時(shí)出現(xiàn)進(jìn)位或做減法時(shí)出現(xiàn)借位,該標(biāo)志位置1;否則清0。PF:奇偶標(biāo)志位。當(dāng)結(jié)果的低 ,8位中I的個(gè)數(shù)為偶數(shù)時(shí),該標(biāo)志位置1;否則清0。AF :半進(jìn)位標(biāo)志位。在加法時(shí),當(dāng)位3需向位4進(jìn)位,或在減法時(shí)位 3需向位4借位時(shí),該標(biāo)志位就置 1;否則清0。該標(biāo)志位通常用于對BCD算術(shù)運(yùn)算結(jié)果的調(diào)整。ZF:零標(biāo)志位。運(yùn)算結(jié)果各位都為0時(shí),該標(biāo)志位置1,否則清0。SF:符號標(biāo)志位。當(dāng)運(yùn)算結(jié)果的最高位為1時(shí),該標(biāo)志位置1,否則清0。TF:陷阱標(biāo)志位(單步標(biāo)志位)。當(dāng)該位置1時(shí),將使8086/8088進(jìn)入單步指令工作方式。 在每條指令開始執(zhí)行以前,CPU總是先測試TF位是否為1,如果
7、為1,則在本指令執(zhí)行后將產(chǎn)生陷阱中斷,從而執(zhí)行陷阱中斷處理程序。該程序的首地址由內(nèi)存的00004H00007H 4個(gè)單元提供。該標(biāo)志通常用于程序的調(diào)試。例如,在系統(tǒng)調(diào)試軟件DEBUG中的T命令,就是利用它來進(jìn)行程序的單步跟蹤的。IF:中斷允許標(biāo)志位。如果該位置1,則處理器可以響應(yīng)可屏蔽中斷,否則就不能響應(yīng)可屏蔽中斷。DF :方向標(biāo)志位。當(dāng)該位置 1時(shí),串操作指令為自動減量指令,即從高地址到低地址 處理字符串;否則串操作指令為自動增量指令。OF:溢出標(biāo)志位。在算術(shù)運(yùn)算中,帶符號的數(shù)的運(yùn)算結(jié)果超出了8位或16位帶符號數(shù)所能表達(dá)的范圍時(shí),即字節(jié)運(yùn)算大于十127或小于-128時(shí),字運(yùn)算大于十 3276
8、7或小于32768時(shí),該標(biāo)志位置位。4.8086/8088系統(tǒng)中存儲器的邏輯地址和物理地址之間有什么關(guān)系?表示的范圍各為多少?解答:邏輯地址:段地址:偏移地址物理地址:也稱為絕對地址,由段基址和偏移量兩部分構(gòu)成。物理地址與系統(tǒng)中的存儲空間是對應(yīng)的。邏輯地址與物理地址兩者之間的關(guān)系為:物理地址=段地址X16+偏移地址每個(gè)邏輯段的地址范圍:0000: 0000HFFFFH ; 0001: 0000HFFFFH ;;FFFF:0000HFFFFH ;共有232個(gè)地址,但其中有許多地址是重疊的表達(dá)出邏輯地址的優(yōu)勢, 可根據(jù)需要方便地寫出邏輯地址,又不影響其準(zhǔn)確的物理地址,邏輯地址與物理地址的關(guān)系為多對
9、一的關(guān)系。物理地址的地址范圍:00000HFFFFFH。5. 已知當(dāng)前數(shù)據(jù)段位于存儲器的A1000H到B0FFFH 范圍內(nèi),問DS= ?解答:A1000Ht A100 : 0000以A100H為段地址的64K物理地址的范圍是:偏移地址為0000H FFFFH,即 A100 : 0000H A100 : FFFFHR A1000H + 0000H A1000H + 0FFFFH =A1000H B0FFFH ,二 DS= A100H。6. 某程序數(shù)據(jù)段中存有兩個(gè)字?jǐn)?shù)據(jù)1234H和5A6BH,假設(shè)已知 DS=5AA0H,它們的偏移地址分別為245AH和3245H,試畫出它們在存儲器中的存放情況解答
10、:存放情況如下圖(左右兩側(cè)的寫法均可):5AA0 :0000H5AA0 :245AH5AA0 :245BH5AA0 :3245H5AA0 :3246H34H12H6BH5AH5AA00H5CE5AH5CE5BH5DC45H5DC46H7. 8086/8088CPU 有哪兩種工作模式,它們各有什么特點(diǎn)?解答:為了適應(yīng)各種不同的應(yīng)用場合,8086/8088CPU芯片可工作在兩種不同的工作模式下,即最小模式與最大模式。所謂最小模式,就是系統(tǒng)中只有一個(gè)8086/8088微處理器,在這種情況下,所有的總線控制信號,都是直接由這片8086/8088CPU產(chǎn)生的,系統(tǒng)中的總線控制邏輯電路被減到最 少。該模式
11、適用于規(guī)模較小的微機(jī)應(yīng)用系統(tǒng)。最大模式是相對于最小模式而言的,最大模式用在中、大規(guī)模的微機(jī)應(yīng)用系統(tǒng)中。在最大模式下,系統(tǒng)中至少包含兩個(gè)微處理器,其中一個(gè)為主處理器,即8086/8088CPU,其它的微處理器稱之為協(xié)處理器,它們是協(xié)助主處理器工作的。& 假設(shè)8086CPU工作于最小模式,試指出當(dāng)CPU完成將AH的內(nèi)容送到物理地址為9100伯 的存儲單元操作時(shí),以下哪些信號應(yīng)為低電平:M/10、RD、WR、BHE /S7、DT/ R。假設(shè)CPU完成的是將物理地址 91000H單元的內(nèi)容送到 AL中,則上述哪些信 號應(yīng)為低電平。假設(shè) CPU為8088呢?解答:8086CPU 存儲器寫(AHH
12、9100H0001H)時(shí)為低電平的信號:WR、BHE /S7。 存儲器讀(9100H00 00HtAL)時(shí)為低電平的信號:RD、DT/ R。8088CPU 存儲器寫(AHH9100H0001H)時(shí)為低電平的信號:WR、BHE /S7、M/ IO。 存儲器讀(9100H0000H tAL)時(shí)為低電平的信號:M/IO、RD、DT/ R。9.什么是指令周期?什么是總線周期?什么是時(shí)鐘周期?它們之間的關(guān)系如何?解答:指令周期-CPU執(zhí)行一條指令所需要的時(shí)間稱為一個(gè)指令周期(Instruction Cycle)??偩€周期-每當(dāng)CPU要從存儲器或I/O端口存取一個(gè)字節(jié)稱為一次總線操作,相應(yīng) 于某個(gè)總線操作
13、的時(shí)間即為一個(gè)總線周期(BUS Cycle)。時(shí)鐘周期-時(shí)鐘周期是CPU處理動作的最小時(shí)間單位,其值等于系統(tǒng)時(shí)鐘頻率的倒數(shù),時(shí)鐘周期又稱為 T狀態(tài)。它們之間的關(guān)系:假設(shè)干個(gè)總線周期構(gòu)成一個(gè)指令周期,一個(gè)基本的總線周期由4個(gè)T組成,我們分別稱為 T1T4,在每個(gè)T狀態(tài)下,CPU完成不同的動作。10 8086/8088 CPU 有哪些基本操作?基本的讀 /寫總線周期各包含多少個(gè)時(shí)鐘周期? 什么情況下需要插入 Tw 周期?應(yīng)插入多少個(gè) Tw 取決于什么因素? 解答: 8086/8088CPU 最小模式下的典型時(shí)序有:存儲器讀寫;輸入輸出;中斷響應(yīng);系統(tǒng)復(fù)位 及總線占用操作。 一個(gè)基本的 CPU 總線
14、周期一般包含四個(gè)狀態(tài) T1、T2、T3、T4 ,即四個(gè)時(shí)鐘周期; 在存儲器和外設(shè)速度較慢時(shí),要在T3之后插入1個(gè)或幾個(gè)等待狀態(tài)Tw ; 應(yīng)插入多少個(gè) Tw 取決于 READY 信號的狀態(tài), CPU 沒有在 T3 狀態(tài)的一開始采樣到READY信號為低電平,就會在T3和T4之間插入等待狀態(tài)Tw,直到采樣到READY信號為 高電平。11 試說明 8086/8088 工作在最大和最小模式下系統(tǒng)基本配置的差異。 8086/8088 微機(jī) 系統(tǒng)中為什么一定要有地址鎖存器?需要鎖存哪些信息?解答: 最大模式配置和最小模式配置有一個(gè)主要的差異:就是在最大模式下, 需要用外加電路來對 CPU 發(fā)出的控制信號進(jìn)行
15、變換和組合,以得到對存儲器和 I/O 端口的讀 /寫信號 及對鎖存器 8282和對總線收發(fā)器 8286等等的控制信號。 8288 總線控制器就是完成 上面這些功能的專用芯片。為多中斷源的需要,常采用中斷優(yōu)先權(quán)控制電路如Intel8259A 。 8086/8088 系統(tǒng)一定要有地址鎖存器 因?yàn)楦咚奈坏刂泛蜖顟B(tài)信號是從同 一組引腳上分時(shí)送出的,低 16 位地址和數(shù)據(jù)是從同一組引腳上分時(shí)傳輸?shù)?,所以必須把?址信息鎖存起來。需要鎖存的信息:地址信號、BHE /S7 和 IO/M 8086 為 M/ IO 信號進(jìn)行鎖存。12試簡述 8086/8088 微機(jī)系統(tǒng)最小模式下從存器儲讀數(shù)據(jù)時(shí)的時(shí)序過程。解答
16、:正常的存儲器讀總線操作占用4個(gè)時(shí)鐘周期,通常將它們稱為 4個(gè)T狀態(tài)即T1T4。 T1 狀態(tài), IO/M=0 ,指出要訪問存儲器。送地址信號 A19-0 ,地址鎖存信號 ALE 有效, 用來控制 8282 鎖存地址。 DT/ R =0,控制 8286/8287 工作在接收狀態(tài)讀。 T2狀態(tài),A19A16送狀態(tài)S6 S3, AD7 ADO浮空,準(zhǔn)備接收數(shù)據(jù)。同時(shí), RD = 0, 表示要進(jìn)行讀操作,而 DEN =0 作為 8286/8287 的選通信號,允許進(jìn)行數(shù)據(jù)傳輸。 T3 狀態(tài),從指定的存儲單元將數(shù)據(jù)讀出送 AD7 AD0 。假設(shè)存儲器速度較慢,不能及時(shí) 讀出數(shù)據(jù)的話,則通過 READY引
17、腳通知CPU , CPU在T3的前沿采樣 READY,如果 READY = 0,則在T3結(jié)束后自動插入1個(gè)或幾個(gè)等待狀態(tài) TW,并在每個(gè)TW的前沿檢 測 READY ,等到 READY 變高后,就自動脫離 TW 進(jìn)入 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ù)在哪 里?如在存儲器中請寫出其物理
18、地址是多少?1MOV AX ,0ABH 2 MOV AX ,100H3MOV AX ,VAL 4MOV BX ,SI5MOV AL ,VALBX 6MOV CL , BXSI7MOV VALSI ,BX 8MOV BPSI ,100解答:1MOV AX ,0ABH 尋址方式:立即尋址;源操作數(shù)在數(shù)據(jù)線上;物理地址:無2MOV AX ,100H尋址方式:直接尋址;源操作數(shù)在存儲器中;物理地址:DS* 16+100H =2000H*16+100H = 20100H3MOV AX ,VAL尋址方式:直接尋址;源操作數(shù)在存儲器中;物理地址:DS* 16+VAL =2000H*16+0050H =200
19、50H4MOV BX ,SI尋址方式:寄存器間接尋址;源操作數(shù)在存儲器中;物理地址:DS * 16+SI =2000H*16+00A0H = 200A0H5MOV AL ,VALBX尋址方式:變址尋址;源操作數(shù)在存儲器中;物理地址:DS* 16+VAL+BX =2000H*16+0050H+0100=20150H6MOV CL ,BXSI尋址方式:基址加變址尋址;源操作數(shù)在存儲器中;物理地址:DS * 16+BX+SI =2000H*16+0100H+00A0H=201A0H7MOV VALSI ,BX尋址方式:寄存器尋址;源操作數(shù)在寄存器中;物理地址:無8MOV BPSI ,100尋址方式:
20、立即尋址;源操作數(shù)在;物理地址:無2設(shè)有關(guān)寄存器及存儲單元的內(nèi)容如下:DS=2000H , BX=0100H , AX=1200HSI=0002H , 20100H=12H , 20101H=34H, 20102H=56H , 20103=78H ,21200=2AH, 21201H=4CH, 21202H=0B7H, 21203H=65H 。試說明以下各條指令單獨(dú)執(zhí)行后相關(guān)寄存器或存儲單元的內(nèi)容。1MOV AX ,1800H 2MOV AX ,BX3MOV BX ,1200H 4MOV DX ,1100BX5MOV BXSI ,AL 6MOV AX ,1100BXSI 解答:題號指令執(zhí)行結(jié)果
21、1 MOV AX ,1800H AX = 1800H2MOV AX ,BX AX = 0100H3MOV BX ,1200H BX = 4C2AH4MOV DX ,1100BX DX = 4C2AH5MOV BXSI , AL 20102H = 00H6MOV AX , 1100BXSI AX = 65B7H 3假定 BX=0E3H ,變量 VALUE=79H ,確定以下指令執(zhí)行后的結(jié)果 (操作數(shù)均為無符號數(shù)。 對 3、 6,寫出相應(yīng)標(biāo)志位的狀態(tài) )。1 ADD VALUE , BX 2 AND BX , VALUE3 CMP BX, VALUE 4 XOR BX , 0FFH5 DEC BX
22、 6 TEST BX, 01H 解答:題號指令執(zhí)行結(jié)果1ADD VALUE , BX BX = 015CH2AND BX , VALUE BX = 0061H3CMP BX , VALUE BX = 00E3H(CF=ZF=OF=SF=0 , AF=PF=1)4XOR BX , 0FFH BX = 001CH5DEC BX BX = 00E2H6TEST BX , 01H BX = OOE3H(CF=ZF=OF=SF=AF=PF=O)4已知 SS=0FFA0H , SP=00B0H ,先執(zhí)行兩條把 令,再執(zhí)行一條 POP 指令,試畫出堆棧區(qū)和 SP 的地址解答: 00ADH00AEH00AFH
23、0FFA0: 00B0HFFAACH FFAADH FFAAEH FFAAFH FFAB0H 00ACHXFFAABH00ADH00AEH00AFH0FFA0: 00B0H 57H80HFFAACH FFAADH FFAAEH FFAAFH FFAB0H 00ACHXFFAABH8057H 和 0F79H 分別進(jìn)棧的 PUSH 指內(nèi)容變化的過程示意圖。 標(biāo)出存儲單元AX = 8057H SP= 00AEH初始狀態(tài);SP= 00B0HPUSH AX ;00AEH00AFH0FFA0 : 00B0H79H0FH57H80HFFAACHFFAADHFFAAEHFFAAFHFFAB0H00ACHXFF
24、AABH00ADH00AEH00AFH0FFA0 : 00B0H57H80HFFAACHFFAADHFFAAEHFFAAFHFFAB0H00ACHXFFAABH PUSH BX ; BX = 0F79HSP= OOACH POP BX ; SP= OOAEH堆棧段 SS= 0FFA0H 堆棧段 SS= 0FFA0H堆棧段 SS= 0FFA0H 堆棧段 SS= 0FFA0H5已知程序段如下:MOV AX , 1234HMOV CL , 4ROL AX , CLDEC AXMOV CX , 4MUL CX試問: 1每條指令執(zhí)行后, AX 寄存器的內(nèi)容是什么? 2每條指令執(zhí)行后, CF,SF 及ZF
25、 的值分別是什么? 3程序運(yùn)行結(jié)束時(shí), AX 及 DX 寄存器的值為多少? 指令執(zhí)行結(jié)果AX CF SF ZFMOV AX , 1234H AX = 1234H XX >MIOV CL , 4 AX = 1234H XXXROL AX , CL AX = 2341H 1 0 0DEC AX AX = 2340H 1 0 0MOV CX , 4 AX = 2340H 1 0 0MUL CX AX = 8D00H , DX=0000H 0 0 06寫出實(shí)現(xiàn)以下計(jì)算的指令序列。假定X、Y 、Z、W、R 都為字變量1Z=W+Z+X 2Z=W-X+6-R+93Z=W*X /R+6 4Z=W-X/5
26、*Y *2解答: 1 Z=W+ Z+X題號指令題號指令1 Z=W+ Z+X 2 Z=W- X+6-R+9MOV AX ,Z MOV DX ,RMOV BX ,X ADD DX ,9MOV CX ,W MOV BX ,XADD BX ADD BX , 6ADC CX MOV AX , WMOV Z ,AX SUB AX ,BXSUB AX , DXMOV Z , AX3 Z= W*X /R+6 4 Z=W-X /5*Y *2MOV DX ,0 MOV AX ,WMOV AX ,W MOV BX ,XMOV BX ,X SUB AX ,BXMUL BX MOV DX , 0PUSH AX MOV
27、CL , 5MOV AX ,R DIV CLADD AX ,6 MOV BX ,YMOV CX ,AX MUL BXPOP AX MOV CL , 2DIV CX MUL CLMOV Z ,AX MOV Z ,AXMOV Z+1 ,DX MOV Z+1 , DX1SHR DX , 1 2SHL DL ,13SAL DH , 1 4SAR DX ,CL5ROR DX , CL6ROL DL,CL7RCR DL , 1 8RCL DX ,CL解答:題號指令執(zhí)行結(jié)果1 SHR DX,1 DX=0110 0100 1101 1100(64DCH) 2 SHL DL ,1 DX=1100 1001 01
28、11 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í)行后
29、DX、 AX 的值各是什么?該程 序完成了什么功能?MOV CL , 4SHL DX , CLMOV BL , AHSHL BL , CLSHR BL,CLOR DL ,BL解答: DX=2345H ,AX=6780H 。該程序完成的功能如下圖,將 DX ,AX 拼裝成雙字后, 左移四位。DXDXAX1 2 3 45 6 7 8DXAX2 3 4 06 7 8 02 3 4 5 6 7 8 0 AX 9試分析以下程序段:ADD AX ,BXJNC L2SUB AX ,BXJNC L3JMP SHORTL5如果 AX 、BX 的內(nèi)容給定如下:AX BX114C6H 80DCH2B568H 54B
30、7H 問該程序在上述情況下執(zhí)行后,程序轉(zhuǎn)向何處?解答:1AX = AX+BX = 14C6H+80DCH = 95A2H ; CF= 0;無進(jìn)位,轉(zhuǎn)移至 L2 ; 2AX = AX+BX = B568H+54B7H = OA仆H ; CF= 1;有進(jìn)位,繼續(xù)執(zhí)行;AX = AX-BX = 0A1FH+54B7H = B568H ; CF= 1 ;有借位,繼續(xù)執(zhí)行; 無條件轉(zhuǎn)移至 SHORTL5 10編寫一段程序,比較兩個(gè) 5 字節(jié)的字符串 OLDS 和 NEWS ,如果 OLDS 字符串不同 于 NEWS 字符串,則執(zhí)行 NEW_LESS ,否則順序執(zhí)行。解答:編程如下,說明:左測 程序?yàn)槌R?guī)
31、編法,兩個(gè)字符串在一個(gè)數(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è)在數(shù)據(jù)
32、段中從字節(jié)變量TABLE 相應(yīng)的單元開始存放了 015 的平方值,試寫出包含有XLAT 指令的指令序列查找 N 015的平方。設(shè) N的值存放在 CL中解答:MOV BX ,OFFSET TABLE ;LEA BX ,TABLEMOV CL ,NMOV AL ,CLXLAT12有兩個(gè)雙字?jǐn)?shù)據(jù)串分別存放在ASC1 和 ASC2 中低字放低地址,求它們的差,結(jié)果放在 ASC3 中低字放低地址。ASC1 DW 578 ,400ASC2 DW 694 ,12ASC3 DW ?,? 解答:編程如下, LEA SI ,ASC1 LEA DI ,ASC2 LEA BX ,ASC3 MOV CX ,2CLCNE
33、XT : MOV AX ,SIMOV DX ,DISBB AX ,DXMOV BX ,AXINC SIINC SIINC DIINC DI INC BXINC BXLOOP NEXTCH03匯編語言程序設(shè)計(jì)1以下語句在存儲器中分別為變量分配多少字節(jié)空間?并畫出存儲空間的分配圖。VAR1 DB 10,2VAR2 DW 5 DUP ?,0VAR3 DB ' HOW ARE YOU ? ' 3 DUP 1,2VAR4 DD -1,1,0解答:字節(jié)空間-VAR1 : 2; VAR2 : 12; VAR3 : 20; VAR4 : 12。存儲空間的分配圖:DS : 0000 0A 02
34、00 00 00 00 00 00 00 00 00 00 00 00 48 4F001057 20 20 41 52 45 20 20 59 4F 55 3F 01 02 01 02002001 02 FF FF FF FF 01 0000 00 00 00 00 002. 假定VAR1和VAR2為字變量,LAB為標(biāo)號,試指出以下指令的錯(cuò)誤之處。1ADD VAR1 , VAR2 2SUB AL , VAR13JMP LABCX4JNZ VAR15MOV 1000H , 100 6SHL AL ,4解答:(1)兩個(gè)操作數(shù)中至少有一個(gè)為寄存器;(2) AL為字節(jié),VAR1為字變量,不匹配;(3)
35、 中不能用CX , LAB為標(biāo)號,非變量;(4) 轉(zhuǎn)向地址應(yīng)為標(biāo)號,不能是變量;(5) 目的操作數(shù)的類型不確定;(6) SHL指令中,當(dāng)所移位數(shù)超過 1時(shí),必須用CL或CX來取代所移位數(shù)。3. 對于下面的符號定義,指出以下指令的錯(cuò)誤。A1 DB ?A2 DB 10K1 EQU 10241 MOV K1 , AX 2MOV A1 , AX3CMP A1 , A2 4K1 EQU 2048解答:(1)K1為常量,不能用 MOV指令賦值;(2) A1為字節(jié),AX為字變量,不匹配;(3) A1未定義,無法做比較指令;(4) K1重新賦值前,必須用 PURGE釋放。4. 數(shù)據(jù)定義語句如下所示:FIRST
36、 DB 90H , 5FH , 6EH , 69HSECOND DB 5 DUP(?)THIRD DB 5 DUP(?)自FIRST單元開始存放的是一個(gè)四字節(jié)的十六進(jìn)制數(shù)(低位字節(jié)在前),要求:編一段程序?qū)⑦@個(gè)數(shù)左移兩位后存放到自SECOND開始的單元,右移兩位后存放到自THIRD 開始的單元。 (注意保留移出部分 ) 解答:DATA SEGMENTFIRST DB 90H , 5FH, 6EH, 69HSECOND DB 5 DUP(?)THIRD DB 5 DUP(?)DATA ENDSCODE SEGMENTASSUME CS :CODE ,DS:DATASTART :MOV AX ,D
37、ATAMOV DS , AXLEA SI , FIRSTLEA DI ,SECONDMOV CX , 2CLC;左移 2 位MOV AX ,SI ;AX=5F90H 為低十六位數(shù)據(jù)INC SIINC SIMOV DX ,SI ;DX=696EH 為高十六位數(shù)據(jù)PUSH DX ;保存原有的高十六位數(shù)據(jù)PUSH AX ;保存原有的低十六位數(shù)據(jù)ROL DX , CL;將高位數(shù)據(jù)不帶進(jìn)位循環(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ù)不
38、帶進(jìn)位循環(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ù)算術(shù)邏輯左移2位SHL AX,CL ;將低位數(shù)據(jù)算術(shù)邏輯左移2位OR DL,BL ;將AX中移出的高2位數(shù)據(jù)放入 DX的低2位MOV DI , AXMOV DI+2, DX;右移 2 位LEA SI , FIRSTLEA DI , THIRDMOV CX , 2CLCMOV AX , SI ; AX=5F90H 為低十六
39、位數(shù)據(jù)INC SIINC SIMOV DX , SI ; DX=696EH 為高十六位數(shù)據(jù)PUSH DX ;保存原有的高十六位數(shù)據(jù) PUSH AX ;保存原有的低十六位數(shù)據(jù)ROR AX,CL ;將低位數(shù)據(jù)不帶進(jìn)位循環(huán)右移兩位,即低2位數(shù)據(jù)在AH的高2位AND AH,0C0H ;讓AH中僅保存移出的低 2位數(shù)據(jù)PUSH CXMOV CX , 6SHR AH , CLPOP CXMOV DI , AH ;將移出的低 2 位數(shù)據(jù)放入 THIRD 中的最低單元中ROR DX,CL ;將低位數(shù)據(jù)不帶進(jìn)位循環(huán)左移兩位,即AX的高2位在AL的低2位AND DH , 0C0H ;讓 DH 中僅保存移出的 DX
40、 低 2 位數(shù)據(jù)MOV BL ,DH ;將 DH 中的數(shù)據(jù)放入 BL 中保存POP AX ;彈出原有的低十六位數(shù)據(jù)POP DX ;彈出原有的高十六位數(shù)據(jù)SHR DX , CL ;將高位數(shù)據(jù)算術(shù)邏輯左移 2 位SHR AX , CL ;將低位數(shù)據(jù)算術(shù)邏輯左移 2位OR AH , BL ;將 DX 中移出的低 2 位數(shù)據(jù)放入 AX 的高 2 位MOV DI+1, AXMOV DI+3, DXMOV AH , 4CHINT 21HCODE ENDSEND START 5 14在當(dāng)前數(shù)據(jù)區(qū)從 400H 開始的 256 個(gè)單元中存放著一組數(shù)據(jù),試編程序?qū)⑺鼈冺?序搬移到從 A000H 開始的順序 256
41、 個(gè)單元中。解答:DATA SEGMENTORG 400HDAT1 DB .;256 DUP (?)ORG 0A000HDAT2 DB .;256 DUP (?)DATA ENDSJSTACK SEGMENTSTACK ENDSJCODE SEGMENTASSUME DS:DATA,CS:CODE,SS:STACK,ES:DATASTART: MOV AX,DATAMOV DS,AX;CH3-14LEA SI,DAT1 LEA DI,DAT2MOV CX,128AGAIN: MOV AL,SIMOV DI,ALINC SIINC DILOOP AGAIN;CH3-15, 將兩個(gè)數(shù)據(jù)塊逐個(gè)單元進(jìn)
42、行比較,假設(shè)有錯(cuò) BL=00H ,否則 BL=FFHLEA SI,DAT1LEA DI,DAT2MOV CX,128NEXT: MOV AL,SIMOV BL,DICMP AL,BLJNZ ERRORINC SIINC DILOOP NEXTMOV BL,0FFHJMP EXITERROR: MOV BL,00HEXIT: MOV AX,4C00HINT 21HCODE ENDS END START 6試編程序?qū)?dāng)前數(shù)據(jù)區(qū)從 BUFF 開始的 4K 個(gè)單元中均寫入 55H ,并逐個(gè)單元讀出比較 看寫入的與讀出的是否一致。假設(shè)全對,則將 ERR 單元置 0H ;如果有錯(cuò),則將 ERR 單 元 置
43、 FFH 。解答:DATA SEGMENT BUFF DB 1000H DUP(?) ERR DB ?DATA ENDSJCODE SEGMENTASSUME CS:CODE,DS:DATASTART: MOV AX,DATAMOV DS,AX;將 55H 依次放入 BUFF 開始的 4K 個(gè)單元LEA SI,BUFFMOV CX,1000H MOV AL,55HNTXT: MOV SI,ALINC SILOOP NEXT;取出與 55H 比較,全對則 ERR=0 ,否則 ERR=FFHLEA DI,BUFFLEA SI,ERRMOV CX,1000HNEXT1: MOV AL,DIINC D
44、ICMP AL,55HJNZ ERROR ;假設(shè)有一個(gè)不同,即置 ERR=FFHLOOP NEXT1MOV AL,00HMOV SI,AL ;全比較完無錯(cuò),則置 ERR=0JMP EXITERROR: MOV AL,0FFHMOV SI,AL;返回 DOS EXIT: MOV AH,4CH INT 21H CODE ENDS END START END7在上題中,如果發(fā)現(xiàn)有錯(cuò)時(shí),要求在ERR 單元中存放出錯(cuò)的數(shù)據(jù)個(gè)數(shù),則程序該如何修改?解答:DATA SEGMENTBUFF DB 1000H DUP(?)ERR DW ?DATA ENDSCODE SEGMENTASSUME CS:CODE,D
45、S:DATASTART: MOV AX,DATAMOV DS,AX;將 55H 依次放入 BUFF 開始的 4K 個(gè)單元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 ;假設(shè)相同,則比較下一個(gè)INC DX ;否則將放出錯(cuò)個(gè)數(shù)的 DX 加 1NEXT2 : LOOP NEXT1MOV SI,DXEXIT: MOV AH,4CH
46、INT 21HCODE ENDSEND STARTEND0100H 開始的一串字節(jié)數(shù)據(jù)逐個(gè)從 F0H 端口輸出,已8試編寫程序段,完成將數(shù)據(jù)區(qū)從 知數(shù)據(jù)串以 0AH 為結(jié)束符。 解答:DATA SEGMENTORG 0100HDATA1 DB N DUP(?)DATA ENDSCODE SEGMENTASSUME CS:CODE,DS:DATASTART: MOV AX,DATAMOV DS,AX;將 DATA1 數(shù)據(jù)串中的數(shù)據(jù)取出并從 F0H 端口中輸出LEA SI,DATA1MOV CX,NMOV BL,0AHNTXT: MOV AL,SICMP AL,BLJZ EXITOUT 0F0H,
47、ALINC SILOOP NEXT;返回 DOSEXIT: MOV AH,4CHINT 21HCODE ENDS END STARTEND9(24) 內(nèi)存中以 FIRST 和 SECOND 開始的單元中分別存放著兩個(gè) 4 位用壓縮 BCD 碼表 示的十進(jìn)制數(shù) , 低位在前。編程序求這兩個(gè)數(shù)的和,仍用壓縮 BCD 碼表示 , 并存到以 THIRD 開始的單元。解答:DATA SEGMENTFIRST DW 3412HSECOND DW 7856HTHIRD DB ?,?,?DATA ENDSJSTACK SEGMENTSTACK ENDSJCODE SEGMENTASSUME DS:DATA,C
48、S:CODE,SS:STACK,ES:DATASTART: MOV AX,DATAMOV DS,AXLEA SI,FIRSTLEA DI,SECONDLEA BX,THIRDMOV CX,2CLCAGAIN: MOV AL,BYTE PTRSIMOV DL,BYTE PTRDIADC AL,DLDAAMOV BYTE PTRBX,ALINC SIINC DIINC BXLOOP AGAINJC AAMOV BYTE PTRBX,0JMP EXITAA: MOV BYTE PTRBX,1EXIT: MOV AX,4C00HINT 21HCODE ENDSEND START 10 (27)設(shè)字變量
49、單元 A、B、 C 存放有三個(gè)數(shù),假設(shè)三個(gè)數(shù)都不為零,則求三個(gè)數(shù)的和, 存放在 D 中;假設(shè)有一個(gè)為零,則將其余兩個(gè)也清零,試編寫程序。解答:DATA SEGMENTA DB ?B DB ?C DB ?D DW ?DATA ENDSJSTACK SEGMENTSTACK ENDSCODE SEGMENTASSUME DS:DATA,CS:CODE,SS:STACK,ES:DATASTART: MOV AX,DATAMOV DS,AXLEA SI,ALEA DI,DMOV AL,SICMP AL,00JZ ZEROADC DX,ALLEA SI,BMOV AL,SICMP AL,00JZ ZER
50、OADC DX,ALLEA SI,CMOV AL,SICMP AL,00JZ ZEROADC DX,ALMOV DI,DXJMP EXITZERO: MOV AL,0MOV A,ALMOV B,ALMOV C,AL ;EXIT: MOV AX,4C00HINT 21HCODE ENDSEND START11. (16)試編程序,統(tǒng)計(jì)由TABLE開始的128個(gè)單元中所存放的字符“ A'的個(gè)數(shù),并將結(jié)果存放在 DX 中。解答:DATA SEGMENTTABLE DB X1,X2,.X128DATA ENDSJSTACK SEGMENTSTACK ENDSJCODE SEGMENTASSUM
51、E DS:DATA,CS:CODE,SS:STACK,ES:DATASTART: MOV AX,DATAMOV DS,AXLEA SI,TABLEMOV DX,0MOV CX,128AGAIN: MOV AL,SICMP AL,'A'JNZ NEXTINC DXNEXT: INC SILOOP AGAINMOV AX,4C00HINT 21HCODE ENDSEND START12試編制一個(gè)匯編語言程序,求出首地址為DATA 的 1000 個(gè)字?jǐn)?shù)組中的最小偶數(shù),并把它存放于 MIN 單元中。解答:DATA SEGMENTARRAY DW X1,X2,.X1000ARRAY_EV
52、EN DW 1000 DUP(?) MIN DW ?MAX DW ?DATA ENDSJSTACK SEGMENTSTACK ENDSJCODE SEGMENTASSUME DS:DATA,CS:CODE,SS:STACK,ES:DATASTART: MOV AX,DATAMOV DS,AX;將數(shù)組中的偶數(shù)放入 ARRAY_EVEN 中LEA SI,ARRAYLEA DI,ARRAY_EVENMOV CX,1000AGAIN: MOV AX,SITEST AX,01hJNZ NEXTMOV DI,AXINC DIINC DINEXT: INC SIINC SILOOP AGAIN;找出 ARRAY_EVEN 中的最大數(shù)LEA SI,ARRAY_EVENMOV CX,999MOV AX,SIMOV BX,AXINC SIINC SINEXT: CMP AX,SIJAE LLMOV AX,SILL: INC SIINC SILOOP NEXTMOV MAX,AX;找出 ARRAY_EVEN 中的最
溫馨提示
- 1. 本站所有資源如無特殊說明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請下載最新的WinRAR軟件解壓。
- 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請聯(lián)系上傳者。文件的所有權(quán)益歸上傳用戶所有。
- 3. 本站RAR壓縮包中若帶圖紙,網(wǎng)頁內(nèi)容里面會有圖紙預(yù)覽,若沒有圖紙預(yù)覽就沒有圖紙。
- 4. 未經(jīng)權(quán)益所有人同意不得將文件中的內(nèi)容挪作商業(yè)或盈利用途。
- 5. 人人文庫網(wǎng)僅提供信息存儲空間,僅對用戶上傳內(nèi)容的表現(xiàn)方式做保護(hù)處理,對用戶上傳分享的文檔內(nèi)容本身不做任何修改或編輯,并不能對任何下載內(nèi)容負(fù)責(zé)。
- 6. 下載文件中如有侵權(quán)或不適當(dāng)內(nèi)容,請與我們聯(lián)系,我們立即糾正。
- 7. 本站不保證下載資源的準(zhǔn)確性、安全性和完整性, 同時(shí)也不承擔(dān)用戶因使用這些下載資源對自己和他人造成任何形式的傷害或損失。
最新文檔
- 五年級上冊數(shù)學(xué)聽評課記錄 《平行四邊形》人教版
- 初中數(shù)學(xué)人教版九年級下冊同步聽評課記錄28-2-1 第1課時(shí)《 解直角三角形》
- 2025年筒式采煤機(jī)合作協(xié)議書
- 北師大版七年級下冊數(shù)學(xué)聽評課記錄:第六章《概率初步回顧與思考》
- 部審湘教版七年級數(shù)學(xué)下冊3.3 第2課時(shí)《利用完全平方公式進(jìn)行因式分解》聽評課記錄
- 青島版數(shù)學(xué)七年級下冊《10.1 認(rèn)識二元一次方程組》聽評課記錄2
- 人教版道德與法治八年級上冊5.3《善用法律》聽課評課記錄
- 湘教版數(shù)學(xué)九年級上冊4.1.2《正弦》聽評課記錄
- 五年級上數(shù)學(xué)聽評課記錄
- 土地復(fù)墾合同范本
- 交通信號控制系統(tǒng)檢驗(yàn)批質(zhì)量驗(yàn)收記錄表
- Bankart損傷的診療進(jìn)展培訓(xùn)課件
- 護(hù)理部用藥安全質(zhì)量評價(jià)標(biāo)準(zhǔn)
- 校園信息化設(shè)備管理檢查表
- 新版抗拔樁裂縫及強(qiáng)度驗(yàn)算計(jì)算表格(自動版)
- API SPEC 5DP-2020鉆桿規(guī)范
- 創(chuàng)新思維課件(完整版)
- DB34∕T 4161-2022 全過程工程咨詢服務(wù)管理規(guī)程
- 部編版小學(xué)生語文教師:統(tǒng)編版語文1-6年級語文要素梳理
- 注塑成型工藝參數(shù)知識講解
- 安全生產(chǎn)專業(yè)化管理
評論
0/150
提交評論