微型計算機原理及應用課后答案侯曉霞_第1頁
微型計算機原理及應用課后答案侯曉霞_第2頁
微型計算機原理及應用課后答案侯曉霞_第3頁
微型計算機原理及應用課后答案侯曉霞_第4頁
微型計算機原理及應用課后答案侯曉霞_第5頁
已閱讀5頁,還剩45頁未讀, 繼續(xù)免費閱讀

下載本文檔

版權說明:本文檔由用戶提供并上傳,收益歸屬內容提供方,若內容存在侵權,請進行舉報或認領

文檔簡介

CHOI微型計算機概述

習題與思考題

1.微型計算機由哪些部件組成?各部件的主要功能是什么?

解答:

算術邏輯部件(ALU)

微處理器'累加器、寄存器

(CPU)

控制器

系統(tǒng)總線:AB、CB、DB

(功能:為CPU和其他部件之間提供數(shù)據(jù)、地址

微型計算機'和控制信息的傳輸通道)

微機系統(tǒng)輸入/輸出(I/O)接口:串/并行接口等

(功能:使外部設備和微型機相連)

存儲器:只讀存儲器(ROM)、隨機存儲器(RAM)

(功能:用來存儲信息)

廣操作系統(tǒng)(0S)

系統(tǒng)軟件<

I系統(tǒng)實用程序:匯編、編譯、編輯、調試程序等

外圍設備:打印機、鍵盤、CRT、磁盤控制器等

(注:CPU的功能一一①可以進行算術和邏輯運算;

②可保存少量數(shù)據(jù);

③能對指令進行譯碼并執(zhí)行規(guī)定的動作:

④能和存儲器、外設交換數(shù)據(jù):

⑤提供整修系統(tǒng)所需要的定時和控制;

⑥可以響應其他部件發(fā)來的中斷請示。)

2.8086/8088CPU由哪兩局部組成?它們的主要功能各是什么?是如何協(xié)調工

作的?

解答:

,總線接口部件(BIU):負責與存儲器、I/O端口傳送數(shù)據(jù)

微處理器?

(CPU)執(zhí)行部件(三U):負責指令的執(zhí)行

協(xié)調工作過程:

總線接口部件和執(zhí)行部件并不是同步工作的,它們按以下流水線技術原那

么來協(xié)調管理:

①每當8086的指令隊列中有兩個空字節(jié),或者8088的指令隊列中有一個

空字節(jié)時,總線接口部件就會自動把指令取到指令隊列中。

②每當執(zhí)行部件準備執(zhí)行一條指令時,它會從總線接口部件的指令隊列前

部取出指令的代碼,然后用幾個時鐘周期去執(zhí)行指令。在執(zhí)行指令的過程中,

如果必須訪問存儲器或者輸入/輸出設備,那么,執(zhí)行部件就會請求總線接口部

件進入總線周期,完成訪問內存或者輸入/輸出端口的操作;如果此時總線接口

部件正好處于空閑狀態(tài),那么,會立即響應執(zhí)行部件的總線請求。但有時會遇

到這樣的情況,執(zhí)行部件請求總線接口部件訪問總線時,總線接口部件正在將

某個指令字節(jié)取到指令隊列中,此時總線接口部件將首先完成這個取指令的操

作,然后再去響應執(zhí)行部件發(fā)出的訪問總線的請求。

③當指令隊列已滿,而且執(zhí)行部件又沒有總線訪問請求時,總線接口部件

便進入空閑狀態(tài)。

④在執(zhí)行轉移指令、調用指令和返回指令時,由于程序執(zhí)行的順序發(fā)生了

改變,不再是順序執(zhí)行下面一條指令,這時,指令隊列中己經按順序裝入的字

節(jié)就沒用了。遇到這種情況,指令隊列中的原有內容將被自動消除,總線接口

部件會按轉移位置往指令隊列裝入另一個程序段中的指令。

3.8086/8088CPU中有哪些存放器?各有什么用途?標志存放器F有哪些標志

位?各在什么情況下置位?

解答:

存放器功能

數(shù)據(jù)AX字乘法,字除法,字I/O

存放器BX查表轉換

CX串操作,循環(huán)次數(shù)

DX字節(jié)相乘,字節(jié)相除,間接I/O

變hl-SI源變卅存放器,用于指令的變加尋址

存放器DI目的變址存放器,用于指令的變址尋址

指針SP堆棧指針存放器,與SS一起來確定堆棧在內存中的位置

存放器基數(shù)指針存放器,用于存放基地址,以使8086/8088尋址

BP

更加靈活

控制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、CFo

標志存放器I'的各標志位置位情況:

?CF:進位標志位。做加法時出現(xiàn)進位或做減法時出現(xiàn)借位,該標志位置

1;否那么清0。

?PF:奇偶標志位。當結果的低8位中1的個數(shù)為偶數(shù)時,該標志位置1;

否那么清0。

?AF:半進位標志位。在加法時,當位3需向位4進位,或在減法時位3需

向位4借位時,該標志位就置1;否那么清0o該標志位通常用于對

BCD算術運算結果的調整。

?ZF:零標志位。運算結果各位都為0時,該標志位置1,否那么清0。

實用文檔.

-SF:符號標志位。當運算結果的最高位為1時,該標志位置1,否那么清

Oo

-TF:陷阱標志位(單步標志位)。當該位置1時,將使8086/8088進入單步

指令工作方式。在每條指令開始執(zhí)行以前,CPU總是先測試TF位是否為

1,如果為1,那么在本指令執(zhí)行后將產生陷阱中斷,從而執(zhí)行陷阱中斷處

理程序。該程序的首地址由內存的00004H~00()()7H4個單元提供。該標志

通常用于程序的調試。例如,在系統(tǒng)調試軟件DEBUG中的T命令,就是利

用它來進行程序的單步跟蹤的。

*IF:中斷允許標志位。如果該位置1,那么處理器可以響應可屏蔽中斷,

否那么就不能響應可屏蔽中斷。

?DF:方向標志位。當該位置1時,串操作指令為自動減量指令,即從高地

址到低地址處理字符串;否那么串操作指令為自動增量指令。

?01':溢出標志位。在算術運算中,帶符號的數(shù)的運算結果超出了8位或16

位帶符號數(shù)所能表達的范圍時,即字節(jié)運算大于十127或小于一128

時,字運算大于十32767或小于一32768時,該標志位置位。

4.8086/8088系統(tǒng)中存儲器的邏輯地址和物理地址之間有什么關系?表示的范

圍各為多少?

解答:

邏輯地址:段地址:偏移地址

物理地址:也稱為絕對地址,由段基址和偏移量兩局部構成。物理地址與

系統(tǒng)中的存儲空間是一一對應的。

邏輯地址與物理地址兩者之間的關系為:物理地址=段地址X16+偏移地址

每個邏輯段的地址范圍:0000:0000H?FFFFH;0001:OOOCH?

FFFFH;…;FFFF:0000H?FFFFH;共有2我個地址,但其中有許多地址是重疊

的(表達出邏輯地址的優(yōu)勢,可根據(jù)需要方便地寫出邏輯地址,又不影響其準

確的物理地址,邏輯地址與物理地址的關系為多對一的關系)。

物理地址的地址范圍:00000H?FFFFFH。

5.當前數(shù)據(jù)段位于存儲器的A1000H到BOFFFH范圍內,問DS=?

解答:

A1000H-A100:0000以A100H為段地址的64K物理地址的范圍是:偏

移地址為0000H?FFFFH,即A100:000011-A100:FFFFH-AIOOOH+OOOOH?

Al000H+OFFFFH=A1OOOH?BOFFFH,,DS=A100H。

6.某程序數(shù)據(jù)段中存有兩個字數(shù)據(jù)1234H和5A6BH,假設DS=5AA0H,它們的偏

移地址分別為245AH和3245H,試畫出它們在存儲器中的存放情況

解答:

實用文檔.

存放情況如下圖(左右兩側的寫法均可):

實用文檔.

5AA0:0(XX)H5AAOOH

5AA0:245AH34H5CE5AH

5AA0:245BH12H5CE5BH

*

5AA0:3245H6BH5DC45H

5AA0:3246H5AH5DC46II

7.8086/8088CPU有哪兩種工作模式,它們各有什么特點?

解答:為了適應各種不同的應用場合,8086/8088CPU芯片可工作在兩種不同的

工作模式下,即最小模式與最大模式。

所謂最小模式,就是系統(tǒng)中只有一個8086/8088微處理器,在這種情況

下,所有的總線控制信號,都是直接由這片8086/8088CPL?產生的,系統(tǒng)中的總

線控制邏輯電路被減到最少。該模式適用于規(guī)模較小的微機應用系統(tǒng)。

最大模式是相對于最小模式而言的,最大模式用在中、大規(guī)模的微機應用

系統(tǒng)中。在最大模式下,系統(tǒng)中至少包含兩個微處理器,其中一個為主處理

器,即8086/8088CPL',其它的微處理器稱之為協(xié)處理器,它們是協(xié)助主處理器

工作的。

8.假設8086CPU工作于最小模式,試指出當CPU完成將AH的內容送到物理地

址為91001H的存儲單元操作時,以下哪些信號應為低電平:M/記、記、

WR>麗/S7、DT/'Ro假設CPU完成的是將物理地址91000H單元的內容送

到AL中,那么上述哪些信號應為低電平。假沒CPU為8088呢?(略)

9.什么是指令周期?什么是總線周期?什么是時鐘周期?它們之間的關系如

何?

解答:指令周期CPU執(zhí)行一條指令所需要的時間稱為一個指令周期

(InstructionCycle)o

總線周期一一每當CPU要從存儲器或I/O端口存取一個字節(jié)稱為一次總

線操作,相應于某個總線操作的時間即為一個總線周期(BUSCycle)o

時鐘周期一一時鐘周期是CPU處理動作的最小時間單位,其值等于系統(tǒng)

時鐘頻率的倒數(shù),時鐘周期又稱為T狀態(tài)。

它們之間的關系:假設干個總線周期構成一個指令周期,一個根本的總線

周期由4個T組成,我們分別稱為3?T”在每個T狀態(tài)下,CPU完成不同的動

實用文檔.

實用文檔.

10.8086/8088CPU有哪些根本操作?根本的讀/寫總線周期各包含多少個時

鐘周期?什么情況下需要插入Tw周期?應插入多少個Tw取決于什么因素?

解答:①8086/8088CPU最小模式下的典型時序有:存儲器讀寫;輸入輸出;中

斷響應;系統(tǒng)復位及總線占用操作。

②一個根本的CPU總線周期一般包含四個狀態(tài)T2,T3、T4,即四個時鐘

周期;

③在存儲器和外設速度較慢時,要在T,之后插入1個或幾個等待狀態(tài)Tj

④應插入多少個T,取決于READY信號的狀態(tài),CPU沒有在狀態(tài)的一開始采

樣到READY信號為低電平,就會在T3和T4之間插入等待狀態(tài)直到采樣到

READY信號為高電平。

11.試說明8086/8088工作在最大和最小模式下系統(tǒng)根本配置的差異。

8086/8088微機系統(tǒng)中為什么一定要有地址鎖存器?需要鎖存哪些信息?

(略,見書)

12.試簡述8086/8088微機系統(tǒng)最小模式下從存器儲讀數(shù)據(jù)時的時序過程。

(略,見書)

CH028086/8088指令系統(tǒng)

習題與思考題

1.假定DS=2000H,ES=2100H,SS=1500H,SFOOAOH,BX=0100H,BP=0010H,

數(shù)據(jù)變量VAL的偏移地址為0050H,請指出以下指令源操作數(shù)是什么尋址方

式?源操作數(shù)在哪里?如在存儲器中請寫出其物理地址是多少?

(1)MOVAX,OABII(2)MOVAX,[100II]

(3)MOVAX,VAL(4)MOVBX,[SI]

(5)MOVAL,VAL[BX](6)MOVCL,[BX][SI]

(7)MOVVAL[SI],BX⑻MOV[BP][SI],100

解答:

(1)MOVAX,OABII

尋址方式:立即尋址;物理地址:無

實用文檔.

(2)MOVAX,[100H]

尋址方式:直接尋址;源操作數(shù)在存儲器中;物理地址:DS*16+100H

=2000H*164-100H=20210H

(3)MOVAX,VAL

尋址方式:直接尋址;源操作數(shù)在存儲器中;物理地址:DS*16+VAL

=200011*161005011=2005011

(4)MOVBX,[SI]

尋址方式:存放器間接尋址;源操作數(shù)在存儲器中;物理地址:DS大

16+SI=2000H*16+00A0H=200A0H

(5)MOVAL,VAL[BX]

尋址方式:變址尋址;源操作數(shù)在存儲器中;物理地址:DS*

16+VAL+BX=2000H*16-005011+0100

=20210H

(6)MOVCL,[BX][SI]

尋址方式:基址加變址尋址;源操作數(shù)在存儲器中;物理地址:DS*

16+BX+SI=2000H*16+01OOH+OOAOH

=201A0H

(7)MOVVAL[SI],BX

尋址方式:存放器尋址;源操作數(shù)在存放器中;物理地址:無

(8)MOV[BP][SI],100

尋址方式:立即尋址;物理地址:無

2.設有關存放器及存儲單元的內容如下:

DS=2000II,BX=0100II,AX=1200II,SI=0002II,[202101I]=12Ij,

[20211H]=34H,[20212H]=56H,[20213]=78H,[21200]=2AH,

[21201H]=4CH,[21202H]=0B7H,[21203H]=65Ho

試說明以下各條指令單獨執(zhí)行后相關存放器或存儲單元的內容。

U)MOVAX,1800H(2)MOVAX,BX

(3)MOVBX,[1200H](4)MOVDX,

1100[BX]

(5)MOV[BX][SI],AL(6)MOV

實用文檔.

,1100[BX][SI]

解答:

題號指令執(zhí)行結果

(1)MOVAX,1800HAX=1800H

(2)MOVAX,BXAX=O1OOH

(3)MOVBX,[1200H]BX=4C2AH

(4)MOVDX,11OO[BX]DX=4C2AII

(5)MOV[BX][SI],AL[20212H]=00H

AX,

(6)MOVAX=65B71l

1100[BX][SI]

3.假定BX=0E3H,變量VALUE=79H,確定以下指令執(zhí)行后的結果(操作數(shù)均為無

符號數(shù)。對3、6,寫出相應標志位的狀態(tài))。

(1)ADDVALUE,BX(2)ANDBX,VALUE

(3)CMPBX,VALUE(4)XORBX,OFFH

(5)DECBX⑹TESTBX,01H

解答:

題號指令執(zhí)行結果

(1)ADDVALUE,BXBX=015CH

(2)ANDBX,VALUEBX=0061H

(3)CMPBX,VALUEBX=00E3H(CF=ZF=0F=SF=0,AF=PF=1)

(4)XORBX,OFFHBX=OO1CI1

(5)DECBXBX=00E2H

(6)TESTBX,01HBX=OOE3HtF=ZF二OF二SF二AF=PF=0)

4.SS=OFFAOH,SP=OOBOH,先執(zhí)行兩條把8057H和0F79H分別進棧的PUSH指

令,再執(zhí)行一條POP指令,試畫出堆棧區(qū)和SP內容變化的過程示意圖。(標

出存儲單元的地址)

解答:

實用文檔.

堆棧段SS=OFFAOH堆棧段SS=OFFAOH

FFAABHFFAABH

(X)ACHFFAACHOOACHFFAACH

00ADHFFAADHOOADHFFAADH

OOAEH_FFAAEHOOAEH57HFFAAEH

(M)AFHFFAAFHOOAFH8OHFFAAFH

OFFAO:OOBOHXFFABOHOFFAO:OOBOHXFFABOH

①初始狀態(tài);SP=OOBOH?PUSHAX;(AX=8057H)SP=OOAEH

堆棧段SS=OFFAOH堆棧段SS=OFFAOH

FFAABHFFAABH

(K)ACH79HFFAACHOOACHFFAACH

OOADHOFHFFAADHOOADHFFAADH

OOAEH57HFFAAEHOOAEH57HFFAAEH

OOAFH8OHFFAAFHOOAFH8OHFFAAFH

OFFAO:OOBOHXFFABOHOFFAO:OOBOHXFFABOH

??

③PUSHBX:(BX=0F79H)SP=OOACH?POPBX;SP=OOAEH

5.程序段如下:

MOVAX,1234H

MOVCL,4

ROLAX,CL

DECAX

MOVCX,4

MULCX

試問:m每條指令執(zhí)行后,AX存放器的內容是什么?(2)每條指令執(zhí)行

后,CF,SF及ZF的值分別是什么?(3)程序運行結束時,AX及DX存放器的

值為多少?

實用文檔.

指令執(zhí)行結果

AXCFSFZF

MOVAX,123411AX=1234IIXXX

MOVCL,4AX=1234HXXX

ROLAX,CLAX=2341H100

DECAXAX=2340H100

MOVCX,4AX=2340H100

MULexAX=8D00II,DX=OOOOH000

6.寫出實現(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)⑵Z=W-(X+6)-(R+9)

MOVAX,ZMOVDX,R

MOVBX,XADDDX,9

MOVex,WMOVBX,X

ADDBXADDBX,6

ADCexMOVAX,W

MOVZ,AXSUBAX,BX

SUBAX,DX

MOVZ,AX

⑶Z=(W*X)/(R+6)(4)Z=((W-X)/5*Y)*2

MOVDX,0MOVAX,W

MOVAX,WMOVBX,X

MOVBX,XSUBAX,BX

MULBXMOVDX,0

PUSHAXMOVCL,5

MOVAX,RDIVCL

ADDAX,6MOVBX,Y

MOVCX,AXMULBX

POPAXMOVCL,2

DIVexMULCL

MOVZ,AXMOVZ,AX

MOVZ+l,DXMOVZ+l,DX

7.假定,CL=3,CF=1,試確定以下各條指令單獨執(zhí)行后DX的值。

(1)SHRDX,1(2)SHLDL,1

實用文檔.

⑶SALDH,1(4)SARDX,CL

⑸RORDX,CL(6)ROLDL,CL

⑺RCRDL,1(8)RCLDX,CL

解答:

題號指令執(zhí)行結果

(1)SHRDX,1DX=O11OCHOO11011100(64DCH)

(2)SHLDL,1DX=1100100101110010(C972H)

(3)SALDH,1DX=100100101011100K92B9H)

(4)SARDX,CLDX=11U10010011011KF937H)

⑸RORDX,CLDX=0011100100110111(393711)

(6)ROLDL,CLDX=1100100111001101(C9CDH)

(7)RCRDL,1DX=1100100111011100(C9DCH)

(8)RCLDX,CLDX=010011011100101K4DCFH)

8.DX=1234H,AX=5678H,試分析以下程序執(zhí)行后DX、AX的值各是什么?該程

序完成了什么功能?

MOVCL,4

SHLDX,CL

MOVBL,AH

SHLBL,CL

SHRBL,CL

ORDL,BL

解答:DX=2345H,AX=6780Ho該程序完成的功能如下圖,將DX,AX拼裝成雙字

后,左移四位。

DX

2|3|4|0

DX:AX

23456780

AX

|6|7|8|O|

9.試分析以下程序段:

ADDAX,BX

JNCL2

SUBAX,BX

JNCL3

JMPSHORTL5

如果AX、BX的內容給定如下:

AXBX

(1)14C6H8ODCH

實用文檔.

(2)B568H54B7H

問該程序在上述情況下執(zhí)行后,程序轉向何處?

解答:(1)AX=AX+BX=14C6H+80DCH=95A2H;CF=O;無進位,轉移至L2;

⑵方法同(1),略

10.編寫一段程序,比擬兩個5字節(jié)的字符串OLDS和NEWS,如果OLDS字符串

不同于NEWS字符串,那么執(zhí)行NEW_LESS,否那么順序執(zhí)行。

解答:編程如下,(說明:左測程序為常規(guī)編法,兩個字符串在一個數(shù)據(jù)段中;

右測的程序要求OLDS在數(shù)據(jù)段中,NEWS在附加段中,利用串操作的指令

是可行的)

LEASLOLDS;LEASI,OLDS

LEADI,NEWS;LEADI,NEWS

MOVCX,5;MOVCX,5

NEXT:MOVAL,[SI];CLD

MOVBL,[DI];REPECMPSB

CMPAL,BL;JNZNEW_LESS

JNZNEWLESS;

INCSI;JMPEXIT

INCDI;NEW_LESS:

LOOPNEXT;

??????EXIT:??????

JMPEXIT

NEWLESS:

EXIT:....

11.假設在數(shù)據(jù)段中從字節(jié)變量TABLE相應的單元開始存放了015的平方值,

試寫出包含有XLAT指令的指令序列查找N(015)的平方。(設N的值存

放在CL中)

解答:

MOVBX,OFFSETTABLE;LEABX,TABLE

MOVCL,N

MOVAL,CL

XLAT

12.有兩個雙字數(shù)據(jù)串分別存放在ASCI和ASC2中(低字放低地址),求它們的

差,結果放在ASC3中(低字放低地址)。

ASCIDW578,400

ASC2DW694,12

實用文檔.

ASC3DV?,?

解答:編程如下,

LEASI,ASCI

LEADI,ASC2

LEABX,ASC3

MOVCX,2

CLC

NEXT:MOVAX,[SI]

MOVDX,[DI]

SBBAX,DX

MOV[BX:],AX

INCSI

INCSI

INCDT

INCDI

INCBX

INCBX

LOOPNE:KT

CH03匯編語言程序設計

習題與思考題

1.以下語句在存儲器中分別為變量分配多少字節(jié)空間?并畫出存儲空間的分配

圖。

VARIDB10,2

VAR2DW5DUP(?),0

VAR3DB'HOWAREYOU?3DUP(1,2)

VAR4DD-1,1,0

解答:字節(jié)空間——VAR1:2;VAR2:12;VAR3:19;VAR4:12。

存儲空間的分配圖:

DS:00000A020000000000000000000000

00484F

0010572041524520594F—553F240102

010201

002002FFFFFFFF010000—0000000000

2.假定VAR1和VAR2為字變量,LAB為標號,試指出以下指令的錯誤之處。

(1)ADDVARI,VAR2(2)SUBAL,VARI

實用文檔.

(3)JMPLAB[CX][4)JNZVARI

(5)MOV[1OOOH],100(6)SHLAL,4

解答:(1)兩個操作數(shù)中至少有一個為存放器;

(2)AL為字節(jié),VAR1為字變量,不匹配;

(3)口中不能用CX;

(4)轉向地址應為標號;

(5)目的操作數(shù)的類型不確定;

(6)SHL指令中,當所移位數(shù)超過1時,必須用CL或CX來取代所移位

數(shù)。

3.對于下面的符號定義,指出以下指令的錯誤。

AlDB?

A2DB10

KIEQU1024

(1)MOVKI,AX(2)MOVAl,AX

(3)CMPAl,A2(4)KiEQU

2048

解答:(DKl為常量,不能用MOV指令賦值;

(2)A1為字節(jié),AX為字變量,不匹配;

(3)A1未定義,無法做比擬指令;

(4)K1重新賦值前,必須用PURGE釋放。

4.數(shù)據(jù)定義語句如下所示:

FIRSTDB90H,5FH,6EH,69H

SECONDDB5DUP(?)

THIRDDB5DUP(?)

自FIRST單元開始存放的是一個四字節(jié)的十六進制數(shù)(低位字節(jié)在前),要求:

編一段程序將這個數(shù)左移兩位后存放到自SECOND開始的單元,右移兩位后存

放到自THIRD開始的單元。(注意保存移出局部)

解答:

DATASEGMENT

FIRSTDB90H,5FH,6EH,69H

SECONDDB5DUP(?)

THIRDDB5DUP(?)

DATAENDS

CODESEGMENT

ASSUMECS:CODE,DS:DATA

START:MOVAX,DATA

實用文檔.

MOVDS,AX

LEASI,FIRST

LEADI,SECOND

MOVCX,2

CLC

;左移2位

MOVAX,[SI]

INCSI

INCSI

MOVDX,[SI]

PUSHDX

PUSHAX

ROLDX,CL

ANDDL,O3H

MOV[DI+4],DL

ROLAX,CL

ANDAL,03H

MOVBL,AL

POPAX

POPDX

SHLDX,CL

SHLAX,CL

ORDL,BL

MOV[DI],AX

MOV[DI+2],DX

;右移2位,類同左移的方法,略

MOVAH,4CH

INT21H

CODEENDS

ENDSTART

5.1原14)在當前數(shù)據(jù)區(qū)從400H開始的256個單元中存放著一組數(shù)據(jù),試編

程序將它們順序搬移到從A000I1開始的順序256個單元中。

解答:

DATASEGMENT

ORG400H

DAT1DB...;256DUP(?)

ORGOAOOOH

實用文檔.

DAT2DB;256DUP(?)

DATAENDS

STACKSEGMENT

STACKENDS

CODESEGMENT

ASSUMEDS:DATA,CS:CODE,SS:STACK,ES:DATA

START:MOVAX,DATA

MOVDS,AX

;CH3-14

LEASI,DAT1

LEADI,DAT2

MOVCX,128

AGAIN:MOVAL,[ST]

MOV[DI],AL

INCSI

INCDT

LOOPAGAIN

;CH3T5,將兩個數(shù)據(jù)塊逐個單元進行比擬,假設有錯BL=OOH,否那么BL=FFH

LEASI,DAT1

LEADI,DAT2

MOVCX,128

NEXT:MOVAL,[SI]

MOVBL,[DI]

CMPAL,BL

JNZERROR

INCSI

INCDI

LOOPNEXT

MOVBL,OFFH

JMPEXIT

ERROR:MOVBL,OOH

EXIT:MOVAX,4C00H

INT21H

CODEENDS

ENDSTART

6.試編程序將當前數(shù)據(jù)區(qū)從BUFF開始的4K個單元中均寫入55H,并逐個單元

實用文檔.

讀出比擬,看寫入的與讀出的是否一致。假設全對,那么將

實用文檔.

ERR單元置OH;如果有錯,那么將ERR單元置FFH。

解答:

DATASEGMENT

BUFFDB1000HDUP(?)

ERRDB?

DATAENDS

CODESEGMENT

ASSUMECS:CODE,DS:DATA

START:MOVAX,DATA

MOVDS,AX

;將55H依次放入BUFF開始的4K個單元

LEASI,BUFF

MOVCX,1000H

MOVAL,55H

NTXT:MOV[SI],AL

INCSI

LOOPNEXT

;取出與55H比擬,全對那么ERR=O,否那么ERR=FFH

LEADI,BUFF

LEASI,ERR

MOVCX,1000H

NEXT1:MOVAL,[DI]

INCDI

CMPAL,55H

JNZERROR;假設有一個不同,即置ERR二FFH

LOOPNEXT1

MOVAL,OOH

MOV[SI],AL;全比擬完無錯,那么置ERR=O

JMPEXIT

ERROR:MOVAL,OFFH

MOV[SI],AL

;返回DOS

EXIT:MOVAH,4C1I

INT21H

CODEENDS

ENDSTART

END

實用文檔.

7.在上題中,如果發(fā)現(xiàn)有錯時,要求在ERR單元中存放出錯的數(shù)據(jù)個數(shù),那么

程序該如何修改?

解答:

DATASEGMENT

BUFFDB1000HDUP(?)

ERRDW?

DATAENDS

CODESEGMENT

ASSUMECS:CODE,DS:DATA

START:MOVAX,DATA

MOVDS,AX

;將55H依次放入BUFF開始的4K個單元

LEASI,BUFF

MOVCX,1000H

MOVAL,55H

NTXT:MOV[SI],AL

INCST

LOOPNEXT

;取出與55H比擬

LEADI,BUFF

LEASI,ERR

MOVDX,0000H

MOVCX,1000H

NEXT1:MOVAL,[DI]

INCDI

CMPAL,55H

JZNEXT2;假設相同,那么比擬下一個

INCDX;否那么將放出錯個數(shù)的DX加1

NEXT2:LOOPNEXT1

MOV[SI],DX

EXIT:MOVAll,4CII

INT21H

CODEENDS

ENDSTART

END

8.試編寫程序段,完成將數(shù)據(jù)區(qū)從0100H開始的一串字節(jié)數(shù)據(jù)逐個從FOH端口

輸出,數(shù)據(jù)串以OAH為結束符。(略)

實用文檔.

9.(原24)內存中以FIRST和SECOND開始的單元中分別存放著兩個4位用壓縮

BCD碼表示的十進制數(shù),低位在前。編程序求這兩個數(shù)的和,仍用壓縮BCD

碼表示,并存到以THIRD開始的單元。

解答:

DATASEGMENT

FIRSTDW341211

SECONDDW7856II

THIRDDB?,?,?

DATAENDS

STACKSEGMENT

STACKENDS

CODESEGMENT

ASSUMEDS:DATA,CS:CODE,SS:STACK,ES:DATA

START:MOVAX,DATA

MOVDS,AX

LEASI,FIRST

LEADI,SECOND

LEABX,THIRD

MOVCX,2

CLC

AGAIN:MOVAL,BYTEPTR[SI]

MOVDL,BYTEPTR[DI]

ADCAL,DL

DAA

MOVBYTEPTR[BX],AL

INCSI

INCDI

INCBX

LOOPAGAIN

JCAA

MOVBYTEPTR[BX],0

JMPEXIT

AA:MOVBYTEPTR[BX],1

EXIT:MOVAX,4C00H

TNT21H

CODEENDS

實用文檔.

ENDSTART

10.(原27)設字變量單元A、B、C存放有三個數(shù),假設三個數(shù)都不為零,那么

求三個數(shù)的和,存放在D中;假設有一個為零,那么將其余兩個也清零,試

編寫程序。

解答:

DATASEGMENT

ADB?

BDB?

CDB?

DDW?

DATAENDS

STACKSEGMENT

STACKENDS

CODESEGMENT

ASSUMEDS:DATA,CS:CODE,SS:STACK,ES:DATA

START:MOVAX,DATA

MOVDS,AX

LEASI,A

LEADI,D

MOVAL,[SI]

CMPAL,00

JZZERO

ADCDX,AL

LEASI,B

MOVAL,[SI]

CMPAL,00

JZZERO

ADCDX,AL

LEASI,C

MOVAL,[SI]

CMPAL,00

JZZERO

ADCDX,AL

MOV[DI],DX

JMPEXIT

ZERO:MOVAL,0

實用文檔.

MOVA,AL

MOVB,AL

MOVC,AL

EXIT:MOVAX,4C00H

INT21H

CODEENDS

ENDSTART

11.(16)試編程序,統(tǒng)計由TABLE開始的128個單元中所存放的字符“A〃的個

數(shù),并將結果存放在DX中。

解答:

DATASEGMENT

TABLEDBXI,X2,...X128

DATAENDS

STACKSEGMENT

STACKENDS

CODESEGMENT

ASSUMEDS:DATA,OS:CODE,SS:STACK,ES:DATA

START:MOVAX,DATA

MOVDS,AX

LEASI,TABLE

MOVDX,0

MOVCX,128

AGAIN:MOVAL,[SI]

CMPAL/A'

JNZNEXT

INCDX

NEXT:INCSI

LOOPAGAIN

MOVAX,4C00II

INT21H

CODEENDS

ENDSTART

12.試編制一個匯編語言程序,求出首地址為DATA的1000個字數(shù)組中的最小

偶數(shù),并把它存放于MIN單元中。(方法:利用書上排序的例題做相應的修改

即可,略)

實用文檔.

13.在上題中,如果要求同時找出最大和最小的偶數(shù),并把它們分別存放于

MAX和MIN單元中,試完成程序。

解答:略(方法同第12題)。

14.(28)在DATA字數(shù)組中存放有1OOH個16位補碼數(shù),試編寫一程序求它們的

平均值,放在AX中,并求出數(shù)組中有多少個數(shù)小于平均值,將結果存于BX

中。(略)

15.(17)編寫一個子程序,對AL中的數(shù)據(jù)進行偶校驗,并將經過校驗的結果放

回AL中。

解答:

DATASEGMENT

COUNTEQU7

DATAENDS

STACKSEGMENT

STACKENDS

CODESEGMENT

ASSUMEDS:DATA,CS:CODE,SS:STACK,ES:DATA

START:MOVAX,DATA

MOVDS,AX

PUSHAX

MOVDX,0

MOVCX,COUNT

AGAIN:RCRAL,1

JNCL

INCDX

L:LOOPAGAIN

POPAX

TESTDX,01

JZEXIT

ORAL,80

EXIT:MOVAX,4C00H

INT2111

;ANOTHERMETHORD

實用文檔.

JPEXIT

ORAL,80H

EXIT:MOVAX,4C00H

INT21H

CODEENDS

ENDSTART

16.(18)利用上題的予程序,對DATA開始的256個單元的數(shù)據(jù)加上偶校驗,試

編程序。

解答:

DATASEGMENT

DATDB...;256DUP(?)

RESULTDB...;256DUP(?)

NUMEQU256

COUNTEQU7

DATAENDS

STACKSEGMENT

STACKENDS

CODESEGMENT

ASSUMEDS:DATA,CS:CODE,SS:STACK,ES:DATA

START:MOVAX,DATA

MOVDS,AX

LEASI,DAT

LEADI,RESULT

MOVCX,NUM

NEXT:MOVAL,[SI]

CALLSUB1

MOV[DI],AL;MOV[SI]

溫馨提示

  • 1. 本站所有資源如無特殊說明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請下載最新的WinRAR軟件解壓。
  • 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請聯(lián)系上傳者。文件的所有權益歸上傳用戶所有。
  • 3. 本站RAR壓縮包中若帶圖紙,網頁內容里面會有圖紙預覽,若沒有圖紙預覽就沒有圖紙。
  • 4. 未經權益所有人同意不得將文件中的內容挪作商業(yè)或盈利用途。
  • 5. 人人文庫網僅提供信息存儲空間,僅對用戶上傳內容的表現(xiàn)方式做保護處理,對用戶上傳分享的文檔內容本身不做任何修改或編輯,并不能對任何下載內容負責。
  • 6. 下載文件中如有侵權或不適當內容,請與我們聯(lián)系,我們立即糾正。
  • 7. 本站不保證下載資源的準確性、安全性和完整性, 同時也不承擔用戶因使用這些下載資源對自己和他人造成任何形式的傷害或損失。

評論

0/150

提交評論