2022年微型計(jì)算機(jī)原理及應(yīng)用課后答案侯曉霞_第1頁
2022年微型計(jì)算機(jī)原理及應(yīng)用課后答案侯曉霞_第2頁
2022年微型計(jì)算機(jī)原理及應(yīng)用課后答案侯曉霞_第3頁
2022年微型計(jì)算機(jī)原理及應(yīng)用課后答案侯曉霞_第4頁
2022年微型計(jì)算機(jī)原理及應(yīng)用課后答案侯曉霞_第5頁
已閱讀5頁,還剩39頁未讀 繼續(xù)免費(fèi)閱讀

下載本文檔

版權(quán)說明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請(qǐng)進(jìn)行舉報(bào)或認(rèn)領(lǐng)

文檔簡(jiǎn)介

1、ch01微型計(jì)算機(jī)概述習(xí)題與思考題1微型計(jì)算機(jī)由哪些部件組成?各部件的主要功能是什么?解答:微機(jī)系統(tǒng)微型計(jì)算機(jī)系統(tǒng)軟件外圍設(shè)備:打印機(jī)、鍵盤、crt 、磁盤控制器等微處理器(cpu )系統(tǒng)總線:ab、cb 、db(功能:為cpu 和其他部件之間提供數(shù)據(jù)、地址和控制信息的傳輸通道)存儲(chǔ)器:只讀存儲(chǔ)器(rom )、隨機(jī)存儲(chǔ)器(ram )(功能:用來存儲(chǔ)信息)輸入 / 輸出( i/o )接口:串 / 并行接口等(功能:使外部設(shè)備和微型機(jī)相連)算術(shù)邏輯部件(alu)累加器、寄存器控制器操作系統(tǒng)(os )系統(tǒng)實(shí)用程序:匯編、編譯、編輯、調(diào)試程序等(注: cpu 的功能可以進(jìn)行算術(shù)和邏輯運(yùn)算;可保存少量數(shù)

2、據(jù);能對(duì)指令進(jìn)行譯碼并執(zhí)行規(guī)定的動(dòng)作;能和存儲(chǔ)器、外設(shè)交換數(shù)據(jù);提供整修系統(tǒng)所需要的定時(shí)和控制;可以響應(yīng)其他部件發(fā)來的中斷請(qǐng)示。)28086/8088 cpu 由哪兩部分組成?它們的主要功能各是什么?是如何協(xié)調(diào)工作的?解答:微處理器(cpu )總線接口部件(biu ):負(fù)責(zé)與存儲(chǔ)器、i/o 端口傳送數(shù)據(jù)執(zhí)行部件( eu):負(fù)責(zé)指令的執(zhí)行協(xié)調(diào)工作過程:總線接口部件和執(zhí)行部件并不是同步工作的,它們按以下流水線技術(shù)原則來協(xié)調(diào)管理: 每當(dāng) 8086 的指令隊(duì)列中有兩個(gè)空字節(jié),或者8088 的指令隊(duì)列中有一個(gè)空字節(jié)時(shí),總線接口部件就會(huì)自動(dòng)把指令取到指令隊(duì)列中。 每當(dāng)執(zhí)行部件準(zhǔn)備執(zhí)行一條指令時(shí),它會(huì)從總線

3、接口部件的指令隊(duì)列前部取出指令的代碼,然后用幾個(gè)時(shí)鐘周期去執(zhí)行指令。在執(zhí)行指令的過程中,如果必須訪問存儲(chǔ)器或者輸入/ 輸出設(shè)備,那么,執(zhí)行部件就會(huì)請(qǐng)求總線接口部件進(jìn)入總線周期,完成訪問內(nèi)存或者輸入/ 輸出端口的操作;如果此時(shí)總線接口部件正好處于空閑狀態(tài),那么,會(huì)立即響應(yīng)執(zhí)行部件的總線請(qǐng)求。但有時(shí)會(huì)遇精品學(xué)習(xí)資料 可選擇p d f - - - - - - - - - - - - - - 第 1 頁,共 44 頁 - - - - - - - - -精品學(xué)習(xí)資料 可選擇p d f - - - - - - - - - - - - - - 第 1 頁,共 44 頁 - - - - - - - - -到這

4、樣的情況,執(zhí)行部件請(qǐng)求總線接口部件訪問總線時(shí),總線接口部件正在將某個(gè)指令字節(jié)取到指令隊(duì)列中,此時(shí)總線接口部件將首先完成這個(gè)取指令的操作,然后再去響應(yīng)執(zhí)行部件發(fā)出的訪問總線的請(qǐng)求。 當(dāng)指令隊(duì)列已滿,而且執(zhí)行部件又沒有總線訪問請(qǐng)求時(shí),總線接口部件便進(jìn)入空閑狀態(tài)。 在執(zhí)行轉(zhuǎn)移指令、調(diào)用指令和返回指令時(shí),由于程序執(zhí)行的順序發(fā)生了改變,不再是順序執(zhí)行下面一條指令,這時(shí),指令隊(duì)列中已經(jīng)按順序裝入的字節(jié)就沒用了。遇到這種情況,指令隊(duì)列中的原有內(nèi)容將被自動(dòng)消除,總線接口部件會(huì)按轉(zhuǎn)移位置往指令隊(duì)列裝入另一個(gè)程序段中的指令。38086/8088 cpu 中有哪些寄存器?各有什么用途?標(biāo)志寄存器f 有哪些標(biāo)志位?各

5、在什么情況下置位?解答:寄存器功能數(shù)據(jù)寄存器ax 字乘法,字除法,字i/o bx 查表轉(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ū)標(biāo)志寄存器f 的標(biāo)志位:控制標(biāo)志:of 、df

6、、if、tf;狀態(tài)標(biāo)志:sf、zf、af 、pf、cf 。標(biāo)志寄存器 f的各標(biāo)志位置位情況: cf:進(jìn)位標(biāo)志位。做加法時(shí)出現(xiàn)進(jìn)位或做減法時(shí)出現(xiàn)借位,該標(biāo)志位置1;否則清 0。pf :奇偶標(biāo)志位。當(dāng)結(jié)果的低8 位中 l 的個(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)志位通常用于對(duì)bcd算術(shù)運(yùn)算結(jié)果的調(diào)整。zf:零標(biāo)志位。運(yùn)算結(jié)果各位都為0 時(shí),該標(biāo)志位置 1,否則清 0。精品學(xué)習(xí)資料 可選擇p d f - - - - - - - - - - - - - - 第 2 頁,共 4

7、4 頁 - - - - - - - - -精品學(xué)習(xí)資料 可選擇p d f - - - - - - - - - - - - - - 第 2 頁,共 44 頁 - - - - - - - - -sf :符號(hào)標(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總是先測(cè)試tf 位是否為1,如果為1,則在本指令執(zhí)行后將產(chǎn)生陷阱中斷,從而執(zhí)行陷阱中斷處理程序。該程序的首地址由內(nèi)存的00004h00007h 4 個(gè)單元提供。該標(biāo)志通常用于程序的調(diào)試。例如,在系統(tǒng)

8、調(diào)試軟件debug 中的 t 命令,就是利用它來進(jìn)行程序的單步跟蹤的。if:中斷允許標(biāo)志位。如果該位置1,則處理器可以響應(yīng)可屏蔽中斷,否則就不能響應(yīng)可屏蔽中斷。df :方向標(biāo)志位。當(dāng)該位置1 時(shí),串操作指令為自動(dòng)減量指令,即從高地址到低地址處理字符串;否則串操作指令為自動(dòng)增量指令。of :溢出標(biāo)志位。在算術(shù)運(yùn)算中,帶符號(hào)的數(shù)的運(yùn)算結(jié)果超出了8 位或 16位帶符號(hào)數(shù)所能表達(dá)的范圍時(shí),即字節(jié)運(yùn)算大于十127 或小于 128時(shí),字運(yùn)算大于十 32767 或小于 32768時(shí),該標(biāo)志位置位。48086/8088 系統(tǒng)中存儲(chǔ)器的邏輯地址和物理地址之間有什么關(guān)系?表示的范圍各為多少?解答:邏輯地址:段地址

9、:偏移地址物理地址:也稱為絕對(duì)地址,由段基址和偏移量?jī)刹糠謽?gòu)成。物理地址與系統(tǒng)中的存儲(chǔ)空間是一一對(duì)應(yīng)的。邏輯地址與物理地址兩者之間的關(guān)系為:物理地址段地址16+偏移地址每 個(gè) 邏 輯 段 的 地 址 范 圍 : 0000 : 0000h ffffh ; 0001 : 0000hffffh ; ffff :0000h ffffh ;共有 232個(gè)地址,但其中有許多地址是重疊的(體現(xiàn)出邏輯地址的優(yōu)勢(shì),可根據(jù)需要方便地寫出邏輯地址,又不影響其準(zhǔn)確的物理地址,邏輯地址與物理地址的關(guān)系為多對(duì)一的關(guān)系)。物理地址的地址范圍: 00000h fffffh 。5已知當(dāng)前數(shù)據(jù)段位于存儲(chǔ)器的a1000h到 b0f

10、ffh 范圍內(nèi),問 ds= ?解答:a1000h a100 :0000 以 a100h為段地址的 64k 物理地址的范圍是:偏移地址為0000h ffffh ,即 a100:0000h a100:ffffh a1000h 0000h a1000h 0ffffh a1000h b0fffh ,ds a100h 。6某程序數(shù)據(jù)段中存有兩個(gè)字?jǐn)?shù)據(jù)1234h和 5a6bh ,若已知 ds=5aa0h,它們的偏移地址分別為 245ah和 3245h ,試畫出它們?cè)诖鎯?chǔ)器中的存放情況解答:存放情況如圖所示 (左右兩側(cè)的寫法均可 ) :精品學(xué)習(xí)資料 可選擇p d f - - - - - - - - - -

11、- - - - 第 3 頁,共 44 頁 - - - - - - - - -精品學(xué)習(xí)資料 可選擇p d f - - - - - - - - - - - - - - 第 3 頁,共 44 頁 - - - - - - - - -5aa0:0000h5aa0:245ah5aa0:245bh5aa0:3245h5aa0:3246h34h12h6bh5ah5aa00h5ce5ah5ce5bh5dc45h5dc46h78086/8088cpu有哪兩種工作模式,它們各有什么特點(diǎn)?解答:為了適應(yīng)各種不同的應(yīng)用場(chǎng)合,8086/8088cpu芯片可工作在兩種不同的工作模式下,即最小模式與最大模式。所謂最小模式,就

12、是系統(tǒng)中只有一個(gè)8086/8088 微處理器,在這種情況下,所有的總線控制信號(hào),都是直接由這片8086/8088cpu產(chǎn)生的,系統(tǒng)中的總線控制邏輯電路被減到最少。該模式適用于規(guī)模較小的微機(jī)應(yīng)用系統(tǒng)。最大模式是相對(duì)于最小模式而言的,最大模式用在中、大規(guī)模的微機(jī)應(yīng)用系統(tǒng)中。在最大模式下,系統(tǒng)中至少包含兩個(gè)微處理器,其中一個(gè)為主處理器,即 8086/8088cpu ,其它的微處理器稱之為協(xié)處理器,它們是協(xié)助主處理器工作的。8若 8086cpu 工作于最小模式,試指出當(dāng)cpu完成將 ah的內(nèi)容送到物理地址為 91001h 的存儲(chǔ)單元操作時(shí),以下哪些信號(hào)應(yīng)為低電平:m/io、rd、wr、bhe/s7、d

13、t/r。若 cpu完成的是將物理地址91000h單元的內(nèi)容送到al中,則上述哪些信號(hào)應(yīng)為低電平。若cpu 為 8088呢?(略)9什么是指令周期?什么是總線周期?什么是時(shí)鐘周期?它們之間的關(guān)系如何?解 答: 指令 周 期 -cpu執(zhí) 行 一 條指 令所 需要的 時(shí)間 稱 為 一 個(gè) 指令 周期(instruction cycle)。總線周期 - 每當(dāng) cpu要從存儲(chǔ)器或i/o 端口存取一個(gè)字節(jié)稱為一次總線操作,相應(yīng)于某個(gè)總線操作的時(shí)間即為一個(gè)總線周期(bus cycle) 。時(shí)鐘周期 - 時(shí)鐘周期是cpu處理動(dòng)作的最小時(shí)間單位,其值等于系統(tǒng)時(shí)鐘頻率的倒數(shù),時(shí)鐘周期又稱為t 狀態(tài)。它們之間的關(guān)系

14、:若干個(gè)總線周期構(gòu)成一個(gè)指令周期,一個(gè)基本的總線周期由 4 個(gè) t 組成,我們分別稱為t1t4,在每個(gè) t 狀態(tài)下, cpu完成不同的動(dòng)精品學(xué)習(xí)資料 可選擇p d f - - - - - - - - - - - - - - 第 4 頁,共 44 頁 - - - - - - - - -精品學(xué)習(xí)資料 可選擇p d f - - - - - - - - - - - - - - 第 4 頁,共 44 頁 - - - - - - - - -作。108086/8088 cpu 有哪些基本操作?基本的讀/ 寫總線周期各包含多少個(gè)時(shí)鐘周期?什么情況下需要插入tw周期?應(yīng)插入多少個(gè)tw取決于什么因素?解答: 80

15、86/8088cpu最小模式下的典型時(shí)序有:存儲(chǔ)器讀寫;輸入輸出;中斷響應(yīng);系統(tǒng)復(fù)位及總線占用操作。一個(gè)基本的cpu總線周期一般包含四個(gè)狀態(tài)4321tttt、,即四個(gè)時(shí)鐘周期;在存儲(chǔ)器和外設(shè)速度較慢時(shí),要在3t之后插入 1 個(gè)或幾個(gè)等待狀態(tài)wt;應(yīng)插入多少個(gè)wt取決于 ready 信號(hào)的狀態(tài), cpu沒有在3t狀態(tài)的一開始采樣到 ready 信號(hào)為低電平,就會(huì)在3t和4t 之間插入等待狀態(tài)wt,直到采樣到ready 信號(hào)為高電平。11試說明8086/8088 工作在最大和最小模式下系統(tǒng)基本配置的差異。8086/8088 微機(jī)系統(tǒng)中為什么一定要有地址鎖存器?需要鎖存哪些信息?(略,見書)12試簡(jiǎn)

16、述8086/8088 微機(jī)系統(tǒng)最小模式下從存器儲(chǔ)讀數(shù)據(jù)時(shí)的時(shí)序過程。(略,見書)ch02 80868088 指令系統(tǒng)習(xí)題與思考題1假定ds=2000h ,es=2100h ,ss=1500h ,si=00a0h ,bx=0100h ,bp=0010h ,數(shù)據(jù)變量val 的偏移地址為0050h ,請(qǐng)指出下列指令源操作數(shù)是什么尋址方式?源操作數(shù)在哪里?如在存儲(chǔ)器中請(qǐng)寫出其物理地址是多少?(1)mov ax,0abh (2)mov ax ,100h (3)mov ax ,val (4)mov bx ,si (5)mov al ,valbx (6)mov cl ,bxsi (7)mov valsi,b

17、x (8)mov bpsi,100 解答:(1)mov ax ,0abh 尋址方式:立即尋址;物理地址:無精品學(xué)習(xí)資料 可選擇p d f - - - - - - - - - - - - - - 第 5 頁,共 44 頁 - - - - - - - - -精品學(xué)習(xí)資料 可選擇p d f - - - - - - - - - - - - - - 第 5 頁,共 44 頁 - - - - - - - - -(2)mov ax ,100h 尋址方式:直接尋址;源操作數(shù)在存儲(chǔ)器中;物理地址:ds 16+100h2000h*16+100h 20100h (3)mov ax ,val 尋址方式:直接尋址;源操

18、作數(shù)在存儲(chǔ)器中;物理地址:ds 16+val2000h*16+0050h 20050h (4)mov bx ,si 尋址方式:寄存器間接尋址;源操作數(shù)在存儲(chǔ)器中;物理地址:ds 16+si2000h*16+00a0h 200a0h (5)mov al ,valbx 尋址 方式 :變 址尋 址; 源 操 作 數(shù) 在 存儲(chǔ) 器 中 ; 物 理 地 址: ds16+val+bx 2000h*16+0050h+0100 20150h (6)mov cl ,bxsi 尋址方式:基址加變址尋址;源操作數(shù)在存儲(chǔ)器中;物理地址:ds 16+bx+si 2000h*16+0100h+00a0h 201a0h (

19、7)mov valsi,bx 尋址方式:寄存器尋址;源操作數(shù)在寄存器中;物理地址:無(8)mov bpsi ,100 尋址方式:立即尋址;物理地址:無2設(shè)有關(guān)寄存器及存儲(chǔ)單元的內(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。試說明下列各條指令單獨(dú)執(zhí)行后相關(guān)寄存器或存儲(chǔ)單元的內(nèi)容。(1)mov ax ,1800h (2)mov ax ,bx (3)mov bx ,1200h (4)m

20、ov dx,1100bx (5)mov bxsi,al (6)mov 精品學(xué)習(xí)資料 可選擇p d f - - - - - - - - - - - - - - 第 6 頁,共 44 頁 - - - - - - - - -精品學(xué)習(xí)資料 可選擇p d f - - - - - - - - - - - - - - 第 6 頁,共 44 頁 - - - - - - - - -ax ,1100bxsi 解答:題號(hào)指令執(zhí)行結(jié)果(1)mov ax ,1800h ax 1800h (2)mov ax ,bx ax 0100h (3)mov bx ,1200h bx 4c2ah (4)mov dx ,1100bx

21、dx 4c2ah (5)mov bxsi,al 20102h 00h (6)mov ax,1100bxsi ax 65b7h 3假定 bx=0e3h ,變量 value=79h,確定下列指令執(zhí)行后的結(jié)果( 操作數(shù)均為無符號(hào)數(shù)。對(duì) 3、6,寫出相應(yīng)標(biāo)志位的狀態(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 解答:題號(hào)指令執(zhí)行結(jié)果(1)add value ,bx bx 015ch (2)and bx ,value bx 0061h (3)cmp bx ,va

22、lue 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分別進(jìn)棧的 push指令,再執(zhí)行一條pop指令,試畫出堆棧區(qū)和sp 內(nèi)容變化的過程示意圖。(標(biāo)出存儲(chǔ)單元的地址)解答:精品學(xué)習(xí)資料 可選擇p d f - - - - - - - - - - - - - - 第 7 頁,共 44 頁 - - - - - - - -

23、 -精品學(xué)習(xí)資料 可選擇p d f - - - - - - - - - - - - - - 第 7 頁,共 44 頁 - - - - - - - - -00adh00aeh00afh0ffa0:00b0hffaachffaadhffaaehffaafhffab0h00achxffaabh00adh00aeh00afh0ffa0:00b0h57h80hffaachffaadhffaaehffaafhffab0h00achxffaabh初始狀態(tài);sp00b0hpushax;(ax 8057h)sp00aeh00adh00aeh00afh0ffa0:00b0h79h0fh57h80hffaachff

24、aadhffaaehffaafhffab0h00achxffaabh00adh00aeh00afh0ffa0:00b0h57h80hffaachffaadhffaaehffaafhffab0h00achxffaabhpushbx;(bx0f79h)sp00achpopbx;sp00aeh堆棧段 ss0ffa0h堆棧段 ss 0ffa0h堆棧段 ss0ffa0h堆棧段 ss 0ffa0h5已知程序段如下:mov ax ,1234h mov cl ,4 rol ax ,cl dec ax mov cx ,4 mul cx 試問:(1)每條指令執(zhí)行后,ax 寄存器的內(nèi)容是什么?(2)每條指令執(zhí)行后,

25、cf ,sf及 zf 的值分別是什么?( 3)程序運(yùn)行結(jié)束時(shí), ax及 dx寄存器的值為多少?精品學(xué)習(xí)資料 可選擇p d f - - - - - - - - - - - - - - 第 8 頁,共 44 頁 - - - - - - - - -精品學(xué)習(xí)資料 可選擇p d f - - - - - - - - - - - - - - 第 8 頁,共 44 頁 - - - - - - - - -指令執(zhí)行結(jié)果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

26、0 mov cx ,4 ax 2340h 1 0 0 mul cx ax 8d00h ,dx=0000h 0 0 0 6寫出實(shí)現(xiàn)下列計(jì)算的指令序列。 (假定 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 )題號(hào)指令題號(hào)指令(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 a

27、dd 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 mo

28、v z,ax mov z+1,dx mov z+1,dx 7假定dx=1100100110111001b,cl=3 ,cf=1 ,試確定下列各條指令單獨(dú)執(zhí)行后 dx的值。(1)shr dx ,1 (2)shl dl ,1 精品學(xué)習(xí)資料 可選擇p d f - - - - - - - - - - - - - - 第 9 頁,共 44 頁 - - - - - - - - -精品學(xué)習(xí)資料 可選擇p d f - - - - - - - - - - - - - - 第 9 頁,共 44 頁 - - - - - - - - -(3)sal dh ,1 (4)sar dx ,cl (5)ror dx ,cl

29、(6)rol dl ,cl (7)rcr dl ,1 (8)rcl dx ,cl 解答:題號(hào)指令執(zhí)行結(jié)果(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 1

30、101(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拼裝成雙字后,左移四位。dxdxax12345678dxax2340678023

31、456780ax9試分析下列程序段:add ax ,bx jnc l2 sub ax ,bx jnc l3 jmp shortl5 如果 ax 、bx的內(nèi)容給定如下: ax bx (1)14c6h 80dch 精品學(xué)習(xí)資料 可選擇p d f - - - - - - - - - - - - - - 第 10 頁,共 44 頁 - - - - - - - - -精品學(xué)習(xí)資料 可選擇p d f - - - - - - - - - - - - - - 第 10 頁,共 44 頁 - - - - - - - - -(2)b568h 54b7h 問該程序在上述情況下執(zhí)行后,程序轉(zhuǎn)向何處?解答: (1)ax

32、 ax+bx 14c6h+80dch95a2h ;cf 0;無進(jìn)位,轉(zhuǎn)移至l2;(2)方法同( 1) ,略10編寫一段程序,比較兩個(gè)5 字節(jié)的字符串 olds 和 news,如果 olds 字符串不同于 news 字符串,則執(zhí)行 new_less,否則順序執(zhí)行。解答: 編程如下,(說明:左測(cè)程序?yàn)槌R?guī)編法,兩個(gè)字符串在一個(gè)數(shù)據(jù)段中;右測(cè)的程序要求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 ;

33、 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 相應(yīng)的單元開始存放了015的平方值,試寫出包含有 xlat指令的指令序列查找n (015)的平方。(設(shè) n 的值存放在 cl中)解答:mov bx ,offset table ;lea bx,table mov cl ,n mov al ,cl xlat 12有兩個(gè)雙字?jǐn)?shù)據(jù)串

34、分別存放在asc1和 asc2中(低字放低地址),求它們的差,結(jié)果放在 asc3中(低字放低地址)。asc1 dw 578 ,400 asc2 dw 694,12 精品學(xué)習(xí)資料 可選擇p d f - - - - - - - - - - - - - - 第 11 頁,共 44 頁 - - - - - - - - -精品學(xué)習(xí)資料 可選擇p d f - - - - - - - - - - - - - - 第 11 頁,共 44 頁 - - - - - - - - -asc3 dw ?,?解答: 編程如下,lea si ,asc1 lea di ,asc2 lea bx,asc3 mov cx ,2

35、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 匯編語言程序設(shè)計(jì)習(xí)題與思考題1下列語句在存儲(chǔ)器中分別為變量分配多少字節(jié)空間?并畫出存儲(chǔ)空間的分配圖。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 :19;var4 :12。存儲(chǔ)空間的分配圖:d

36、s :0000 0a 02 00 00 00 00 00 0000 00 00 00 00 00 48 4f 0010 57 20 41 52 45 20 59 4f55 3f 24 01 02 01 02 01 0020 02 ff ff ff ff 01 00 0000 00 00 00 00 2假定 var1和 var2為字變量, lab為標(biāo)號(hào),試指出下列指令的錯(cuò)誤之處。(1)add var1 ,var2 (2)sub al,var1 精品學(xué)習(xí)資料 可選擇p d f - - - - - - - - - - - - - - 第 12 頁,共 44 頁 - - - - - - - - -精品

37、學(xué)習(xí)資料 可選擇p d f - - - - - - - - - - - - - - 第 12 頁,共 44 頁 - - - - - - - - -(3)jmp labcx (4)jnz var1 (5) mov 1000h ,100 (6)shl al, 4 解答: (1) 兩個(gè)操作數(shù)中至少有一個(gè)為寄存器;(2)al 為字節(jié), var1為字變量,不匹配;(3)中不能用 cx ;(4) 轉(zhuǎn)向地址應(yīng)為標(biāo)號(hào);(5) 目的操作數(shù)的類型不確定;(6)shl 指令中,當(dāng)所移位數(shù)超過1 時(shí),必須用cl 或 cx 來取代所移位數(shù)。3對(duì)于下面的符號(hào)定義,指出下列指令的錯(cuò)誤。a1 db ?a2 db 10 k1

38、equ 1024 (1) mov k1,ax (2)mov a1,ax (3)cmp a1,a2 (4)k1 equ2048 解答: (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單元開始存放的是一個(gè)四字節(jié)的十六進(jìn)制數(shù)(低位字節(jié)在前 ), 要求: 編一段程序?qū)⑦@個(gè)數(shù)左移兩位后存放到自second 開始

39、的單元 , 右移兩位后存放到自 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 精品學(xué)習(xí)資料 可選擇p d f - - - - - - - - - - - - - - 第 13 頁,共 44 頁 - - - - - - - - -精品學(xué)習(xí)資料 可選擇p d f - - - - - - - - - -

40、- - - - 第 13 頁,共 44 頁 - - - - - - - - -mov ds ,ax lea si ,first lea di ,second mov cx ,2 clc ;左移 2 位mov ax ,si inc si inc si mov dx ,si push dx push ax rol dx ,cl and dl,03h mov di+4,dl rol ax,cl and al,03h mov bl ,al pop ax pop dx shl dx,cl shl ax,cl or dl,bl mov di ,ax mov di+2 ,dx ;右移 2 位,類同左移的方法

41、,略mov ah ,4ch int 21h code ends end start 5 (原 14)在當(dāng)前數(shù)據(jù)區(qū)從400h開始的 256 個(gè)單元中存放著一組數(shù)據(jù),試編程序?qū)⑺鼈冺樞虬嵋频綇腶000h開始的順序 256 個(gè)單元中。解答:data segment org 400h dat1 db .;256 dup (?) org 0a000h 精品學(xué)習(xí)資料 可選擇p d f - - - - - - - - - - - - - - 第 14 頁,共 44 頁 - - - - - - - - -精品學(xué)習(xí)資料 可選擇p d f - - - - - - - - - - - - - - 第 14 頁,共

42、44 頁 - - - - - - - - -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, 將兩個(gè)數(shù)據(jù)塊逐個(gè)單元進(jìn)行比較,若有錯(cuò)bl=00h ,否則 bl=ffh

43、 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試編程序?qū)?dāng)前數(shù)據(jù)區(qū)從buff開始的 4k 個(gè)單元中均寫入55h ,并逐個(gè)單元精品學(xué)習(xí)資料 可選擇p d f - - - - - - - - - - - - - - 第 15 頁,共 44 頁 - - - - -

44、- - - -精品學(xué)習(xí)資料 可選擇p d f - - - - - - - - - - - - - - 第 15 頁,共 44 頁 - - - - - - - - -讀出比較,看寫入的與讀出的是否一致。若全對(duì),則將err單元置 0h;如果有錯(cuò),則將 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個(gè)單元lea si,buff mov cx

45、,1000h mov al,55h ntxt: mov si,al inc si loop next ; 取出與 55h比較,全對(duì)則 err=0 ,否則 err=ffh lea di,buff lea si,err mov cx,1000h next1: mov al,di inc di cmp al,55h jnz error ;若有一個(gè)不同,即置err=ffh loop next1 mov al,00h mov si,al ;全比較完無錯(cuò),則置err=0 jmp exit error: mov al,0ffh mov si,al ; 返回 dos exit: mov ah,4ch int

46、21h code ends end start end 精品學(xué)習(xí)資料 可選擇p d f - - - - - - - - - - - - - - 第 16 頁,共 44 頁 - - - - - - - - -精品學(xué)習(xí)資料 可選擇p d f - - - - - - - - - - - - - - 第 16 頁,共 44 頁 - - - - - - - - -7在上題中,如果發(fā)現(xiàn)有錯(cuò)時(shí),要求在err單元中存放出錯(cuò)的數(shù)據(jù)個(gè)數(shù),則程序該如何修改?解答:data segment buff db 1000h dup(?) err dw ? data ends code segment assume cs:c

47、ode,ds:data start: mov ax,data mov ds,ax ; 將 55h依次放入 buff開始的 4k個(gè)單元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 ;若相同,則比較下一個(gè)inc dx;否則將放出錯(cuò)個(gè)數(shù)的dx加 1 next2 :loop next1 mov si,dx

48、exit: mov ah,4ch int 21h code ends end start end 8試編寫程序段,完成將數(shù)據(jù)區(qū)從0100h開始的一串字節(jié)數(shù)據(jù)逐個(gè)從f0h端口輸出,已知數(shù)據(jù)串以0ah為結(jié)束符。(略)精品學(xué)習(xí)資料 可選擇p d f - - - - - - - - - - - - - - 第 17 頁,共 44 頁 - - - - - - - - -精品學(xué)習(xí)資料 可選擇p d f - - - - - - - - - - - - - - 第 17 頁,共 44 頁 - - - - - - - - -9( 原 24)內(nèi)存中以 first和 second 開始的單元中分別存放著兩個(gè)4 位用

49、壓縮bcd碼表示的十進(jìn)制數(shù) , 低位在前。編程序求這兩個(gè)數(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:

50、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 exit aa: mov byte ptrbx,1 exit: mov ax,4c00h int 21h code ends 精品學(xué)習(xí)資料 可選擇p d f - - - - - - - - - - - - - - 第 18 頁,共 44 頁 - - - - - - - - -精品學(xué)習(xí)資料 可選擇p d f - - - - - - - - - -

51、 - - - - 第 18 頁,共 44 頁 - - - - - - - - -end start 10( 原 27)設(shè)字變量單元a、b、c 存放有三個(gè)數(shù),若三個(gè)數(shù)都不為零,則求三個(gè)數(shù)的和,存放在d 中;若有一個(gè)為零,則將其余兩個(gè)也清零,試編寫程序。解答: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 d

52、i,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 精品學(xué)習(xí)資料 可選擇p d f - - - - - - - - - - - - - - 第 19 頁,共 44 頁 - - - - - - - - -精品學(xué)習(xí)資料 可選擇p d f - - - - - - - - - - - - - - 第 19 頁,共 44

53、 頁 - - - - - - - - -mov a,al mov b,al mov c,al exit: mov ax,4c00h int 21h code ends end start 11(16) 試編程序,統(tǒng)計(jì)由table開始的 128 個(gè)單元中所存放的字符“ a”的個(gè)數(shù),并將結(jié)果存放在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 d

54、s,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試編制一個(gè)匯編語言程序,求出首地址為data的 1000 個(gè)字?jǐn)?shù)組中的最小偶數(shù),并把它存放于min單元中。 (方法:利用書上排序的例題做相應(yīng)的修改即可,略)精品學(xué)習(xí)資料 可選擇p d f - - - - - - - - - - - - - - 第 20 頁,共 44 頁 - - - - - - - - -

55、精品學(xué)習(xí)資料 可選擇p d f - - - - - - - - - - - - - - 第 20 頁,共 44 頁 - - - - - - - - -13在上題中,如果要求同時(shí)找出最大和最小的偶數(shù),并把它們分別存放于max 和 min單元中,試完成程序。解答: 略(方法同第 12 題) 。14(28) 在 data 字?jǐn)?shù)組中存放有100h個(gè) 16 位補(bǔ)碼數(shù),試編寫一程序求它們的平均值,放在ax 中,并求出數(shù)組中有多少個(gè)數(shù)小于平均值,將結(jié)果存于bx中。 (略)15(17) 編寫一個(gè)子程序,對(duì)al中的數(shù)據(jù)進(jìn)行偶校驗(yàn),并將經(jīng)過校驗(yàn)的結(jié)果放回 al中。解答:data segment count equ

56、 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 精品學(xué)習(xí)資料 可選擇p d f - - - - - -

57、- - - - - - - - 第 21 頁,共 44 頁 - - - - - - - - -精品學(xué)習(xí)資料 可選擇p d f - - - - - - - - - - - - - - 第 21 頁,共 44 頁 - - - - - - - - - jp exit or al,80h exit: mov ax,4c00h int 21h code ends end start 16(18) 利用上題的予程序,對(duì)data 開始的 256 個(gè)單元的數(shù)據(jù)加上偶校驗(yàn),試編程序。解答:data segment dat db .;256 dup (?) result db .;256 dup (?) num

58、equ 256 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 lea si,dat lea di,result mov cx,num next: mov al,si call sub1 mov di,al;mov si,al inc si inc di loop next mov ax,4c00h int 21h sub1 proc push ax mov dx,0 精品學(xué)習(xí)資料 可選

59、擇p d f - - - - - - - - - - - - - - 第 22 頁,共 44 頁 - - - - - - - - -精品學(xué)習(xí)資料 可選擇p d f - - - - - - - - - - - - - - 第 22 頁,共 44 頁 - - - - - - - - - mov cx,count again: rcr al,1 jnc l inc dx l: loop again pop ax test dx,01 jz quit or al,80h quit: ret sub1 endp code ends end start 17(19) 試編寫程序?qū)崿F(xiàn)將鍵盤輸入的小寫字母轉(zhuǎn)換

60、成大寫字母并輸出。解答:data segment mess db the input is not correct.,0dh,0ah,$ data ends stack segment stack ends code segment assume ds:data,cs:code,ss:stack,es:data start: mov ax,data mov ds,ax next: 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

溫馨提示

  • 1. 本站所有資源如無特殊說明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請(qǐng)下載最新的WinRAR軟件解壓。
  • 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請(qǐng)聯(lián)系上傳者。文件的所有權(quán)益歸上傳用戶所有。
  • 3. 本站RAR壓縮包中若帶圖紙,網(wǎng)頁內(nèi)容里面會(huì)有圖紙預(yù)覽,若沒有圖紙預(yù)覽就沒有圖紙。
  • 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ì)自己和他人造成任何形式的傷害或損失。

評(píng)論

0/150

提交評(píng)論