微機原理與接口技術(shù)(樓順天編著)課后習(xí)題答案_第1頁
微機原理與接口技術(shù)(樓順天編著)課后習(xí)題答案_第2頁
微機原理與接口技術(shù)(樓順天編著)課后習(xí)題答案_第3頁
微機原理與接口技術(shù)(樓順天編著)課后習(xí)題答案_第4頁
微機原理與接口技術(shù)(樓順天編著)課后習(xí)題答案_第5頁
已閱讀5頁,還剩75頁未讀 繼續(xù)免費閱讀

下載本文檔

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

文檔簡介

第3章8086CPU指令系統(tǒng)

1.寫出完成下列要求的變量定義語句:

(1)在變量varl中保存6個字變量:4512H,4512,-1,100/3,10H,65530;

(2)在變量var2中保存字符串:'BYTE','word','WORD';

(3)在緩沖區(qū)buf1中留出100個字節(jié)的存儲空間;

(4)在緩沖區(qū)buf2中,保存5個字節(jié)的55H,再保存10個字節(jié)的240,并將這一過程

重復(fù)7次;

(5)在變量var3中保存緩沖區(qū)bufl的長度;

(6)在變量pointer中保存變量varl和緩沖區(qū)bufl的偏移地址。

解:varlDW4512H,4512,-1,100/3,10H,65530

var2DB'BYTE'/word'WORD)

buflDB100DUP(?)

buf2DB7DUP(5DUP(55H),10DUP(240))

var3DBLENGTHbufl

pointerDWvarl,bufl(或者pointerDWOFFSETvarl,OFFSETI

2.設(shè)變量varl的邏輯地址為0100:0000,畫出下列語句定義的變量的存儲分配圖

varlDB12,-12,20/6,4DUP(0,55H)

var2DB'Assemble)

var3DW‘AB','cd','E'

var4DWvar2

var5DDvar2

解:

0100:0000M0CHvarlOOOBH41Hvar20019HOBHvar4

73HOOH

03H73H001BHOBHvar5

OOH65HOOH

55H6DHOOH

OOH62H01H

55H6cH

OOH65H

55H0013H42Hvar3

OOH41H

55H64H

63H

45H

OOH

3.指令正誤判斷,對正確指令寫出源和目的操作數(shù)的尋址方式,對錯誤指令指出原因(設(shè)

VAR1,VAR2為字變量,L1為標(biāo)號):

(1)MOVSI,100(2)MOVBX,VARI[SI]

(3)MOVAX,[BX](4)MOVAL,[DX]

(5)MOVBP,AL(6)MOVVARI,VAR2

(7)MOVCS,AX(8)MOVDS,01OOH

(9)MOV[BX][SI],1(10)MOVAX,VAR1+VAR2

(11)ADDAX,LENGTHVARI(12)ORBL,TYPEVAR2

(13)SUB[DI],78H(14)MOVSVAR1,VAR2

(15)PUSH100H(16)POPCS

(17)XCHGAX,ES(18)MOVDS,CS

(19)JMPL1+5(20)DIVAX,10

(21)SHI,BL,2(22)MOVAL,15+23

(23)MULCX(24)XCHGCL,[SI]

(25)ADCCS:[O1OO],AH(26)SBBVARI-5,154

解:⑴MOVSI,100正確。源:立即數(shù)尋址,目的:寄存器尋址

(2)MOVBX,VARI[SI]正確。源:寄存器相對尋址,目的:寄存器尋址

(3)MOVAX,[BX]正確。源:寄存器間接尋址,目的:寄存器尋址

(4)MOVAL,[DX]錯誤。寄存器間接尋址時,DX,AX,CX不能作地址寄存器

(5)MOVBP,AL錯誤。操作數(shù)類型不一致

(6)MOVV/\R1,VAR2錯誤。兩存儲單元之間不能用MOV指令傳送數(shù)據(jù)

(7)MOVCS,AX錯誤。CS不能為目的操作數(shù)

(8)MOVDS,01OOH錯誤。目的操作數(shù)為段寄存器時,源操作數(shù)不能為立即數(shù)

(9)MOV[BX][Sr|,1錯誤。指令類型不定。

(10)MOVAX,VAR1+VAR2錯誤。MOV指令中不能完成加法運算

(11)ADDAX,LENGTHVARI正確。源:立即數(shù)尋址。目的:寄存器尋址

(12)ORBL,TYPEVAR2正確。源:立即數(shù)尋址。目的:寄存器尋址

(13)SUB[DI],78H錯誤。指令類型不定

(14)MOVSVAR1,VAR2正確。目的、源均為隱含尋址。操作數(shù)僅指出操作數(shù)類型

(15)PUSH100H錯誤。將常數(shù)壓入堆棧,要通過寄存器來實現(xiàn)

(16)POPCS錯誤。目的操作數(shù)不能為CS

(17)XCHGAX,ES錯誤。XCHG指令的操作數(shù)不能是段寄存器

(18)MOVDS,CS錯誤。MOV指令不能從段寄存器到段寄存器

(19)JMPL1+5正確。段內(nèi)直接轉(zhuǎn)移

(20)DIVAX,10錯誤。指令格式錯誤。

(21)SHLBL,2錯誤。移位指令的移位數(shù)為1或者CL

(22)MOVAL,15+23正確。源:立即數(shù)尋址,目的:寄存器。編譯時就處理為38

(23)MULCX正確。源:寄存器尋址,目的:寄存器尋址

(24)XCHGCL,[SI]正確。源:寄存器間接尋址,目的:寄存器尋址

(25)ADCCS:[0100]^H正確。源:寄存器尋址,目的:直接尋址(數(shù)據(jù)在代碼段中)

(26)SBBVARI-5,154正確。源:立即數(shù)尋址,目的:直接尋址。

4.說明下列指令對的區(qū)別:

⑴MOVAX,VARI與MOVAX,OFFSETVARI

⑵MOVAX,VAR2與LEAAX,VAR2

⑶MOVAL,LENGTHVARI與MOVAL,SIZEVARI

(4)MOVAL,ES:[DI]CMPAL,[SI]與CMPSB

⑸SHRAL,1與SARAL,1

(6)SHRAL,1與RORAL,1

⑺ROLBX,1與RCLBX,1

解:(1)MOVAX,VARI把變量VARI對應(yīng)地址單元中的一個字送入AX

MOVAX,OFFSETVARI把VAR1的有效地址的偏移地址送入AX

⑵MOVAX,VAR2把變量VAR2對應(yīng)地址單元中的一個字送入AX

LEAAX,VAR2把VAR2的有效地址的偏移地址送入AX

⑶MOVAL,LENGTHVARI把變量VARI的長度送入AL

MOVAL,SIZEVARI把變量VAR1的大小送入AL

(4)MOVAL,ES:[DI]

CMPAL,[SI]把以ES為段地址,DI為偏移地址的一個字節(jié)送入AL,

并與以SI內(nèi)容為偏移地址的一個字節(jié)作比較,改變標(biāo)志寄

存器內(nèi)容。(相當(dāng)于作ES:(DI)與(DS:(SI)內(nèi)容比較)

CMPSB對字符串中的一字節(jié)比較。尋址方式隱含。源串的地址由

DS:SI指定,目的串的地址由ES:DI指定。(相當(dāng)于作

DS:(SI)與ES:(DI)內(nèi)容比較)

(5)SHRAL,1AL邏輯右移1位,最高位移入0,最低位移入CF。

SARAL,1AL算術(shù)右移1位,以最高位內(nèi)容移入,最低位移入CF,其余各位

右移一位。

(6)SHRAL,1AL邏輯右移1位,最高位移入0,最低位移入CF。

RORAL,1AL的各位構(gòu)成環(huán)形移位,右移一位,最低位內(nèi)容同時移入到CF和

最高位。

(7)ROLBX,1BX各位構(gòu)成環(huán)形移位,左移一位,最高位內(nèi)容同時移入到CF和

最低位。

RCLBX,1BX和CF構(gòu)成環(huán)形移位,左移一位,CF內(nèi)容移入到最低位,最

高位移入CF。

5.寫出下列轉(zhuǎn)移指令的尋址方式(設(shè)L1為標(biāo)號,VAR1為字型變量,DVAR1為雙字型變

量):

(1)JMPLI⑵JMPNEARL1

(3)JNZLI(4)JMPBX

(5)JGLI(6)JMPVAR1[SI]

(7)JMPFARPTRLI(8)JMPDVAR1

解:(1)JMPL1段內(nèi)直接尋址⑵JMPNEARPTRL1段內(nèi)直接尋址

⑶JNZL1段內(nèi)直接尋址(4)JMPBX段內(nèi)間接尋址

(5)JGLI段內(nèi)直接尋址(6)JMPVARI[SI]段內(nèi)間接尋址

(7)JMPFARPTRL1段間直接尋址(8)JMPDVAR1段間間接尋址

6.設(shè)(DS)=2000H,(BX)=0100H,(SI)=0002H,(20100)=341214,(20102)=7856H,

(21200)=4C2AH,(21202)=65B7H,求下列指令執(zhí)行后AX寄存器的內(nèi)容:

(1)MOVAX,1200H;⑵MOVAX,BX;(3)MOVAX,[1200H];

(4)MOVAX,[BXJ;⑸MOVAX,1100[BX];(6)MOVAX,IBX][SIJ;

(7)MOVAX,1100[BX][Sr]

解:(1)1200H(2)01OOH(3)4C2AH(4)3412H(5)4C2AH

(6)7856H(7)65B7H

7.執(zhí)行下列指令后,DX寄存器中的內(nèi)容是多少?

TABLEDW25,36,-1,-16,10000,13

PYLDW7

MOVBX,OFFSETTABLE

ADDBX,PYL

MOVDX,[BX]

解:DX=10FFH由-16(FFFOH)的高8位和10000(2710H)的低8位構(gòu)成

8.如果堆棧的起始地址為2200:0000,棧底為0100H,(SP)=00A8H,求

(D棧頂?shù)刂?

(2)SS的內(nèi)容;

(3)再存入數(shù)據(jù)5678H,3AF2H后,SP的內(nèi)容。

解:棧頂?shù)刂?0A8H,SS=220014,再存入2個字后,SP=00A4H

9.設(shè)已用偽指令EQU定義了4個標(biāo)識符:

N1EQU2100

N2EQU10

N3EQU20000

N4EQU25000

下列指令是否正確?并說明原因。

(1)ADDAL,N1-N2;(2)MOVAX,N3+N4;

(3)SUBBX,N4—N3;(4)SUBAH,N4-N3-N1;

(5)ADDAL,N2;(6)MOVAH,N2*N2

解:(1)錯誤。Nl-N2=2090>255(2)正確(3)正確

(4)錯誤。N4-N3-Nl=2900>255(5)正確(6)正確

10.按下列要求寫出指令:

(1)將AX寄存器的低4位清零,其余位不變;

(2)將BX寄存器的低4位置1,其余位不變;

(3)將AL寄存器的低4位保持不變,高4位取反;

(4)測試BX中的位1和位2,當(dāng)這兩位同時為0時將AL置0FFH,否則AL清零;

(5)測試BX中的位1和位2,當(dāng)這兩位有一位為。時將AL置0FFH,否則AL清零;

(6)將AL中保存的字母ASCH碼變換成相應(yīng)的大寫字母的ASCII碼;

(7)將AL中保存的字母ASCH碼變換成相應(yīng)的小寫字母的ASCH碼;

(8)將AX中的各位取反;

(9)將DX中的低7位取反,高9位不變;

(10)將CX中的低8位與高8位互換。

解:⑴ANDAX,0FFF0H

(2)ORBX,000FH

(3)XORAL,0F0H

(4)TESTBX,06H(5)MOVAX,BX

JZZEROANDAX,06H

MOVAL,OOHXORAX,06H

JMPOVERJZOVER

ZERO:MOVAL,0FFHMOVAL,0FFH

OVER:JMPDONE

OVER:MOVAL,0

DONE:

(6)ANDAL,5FH

或者:

CMPAL,61H

JLOVER(無需變換或不是字母)

CMPAL,7AH

JGOVER(不是字母)

ANDAL,5FH或SUBAL,20H

OVER:

(7)ORAL,20H

或者:

CMPAL,41H

JLOVER(不是字母)

CMPAL,5AH

JGOVER(無需變換或不是字母)

ORAL,20H或ADDAL,20H

OVER:

(8)XORAX,OFFFFH或者NOTAX

(9)XORDX,007FH

(10)XCHGCH,CL

11.寫出完成下述功能的程序段:

(1)傳送40H到AL寄存器;

(2)將AL的內(nèi)容乘以2;

(3)傳送16H到AH寄存器;

(4)AL的內(nèi)容加上AH的內(nèi)容。

計算最后結(jié)果(AL)=?

解:⑴MOVAL,40H

(2)SHLAL,1

(3)MOVAH,16H

(4)ADDAL,AH

AL=96H

12.寫出完成下述功能的程序段:

(1)從緩沖區(qū)BUF的0004偏移地址處傳送一個字到AX寄存器;

(2)將AX寄存器的內(nèi)容右移2位;

(3)將AX內(nèi)容與BUF的0006偏移地址處的一個字相乘;

(4)相乘結(jié)果存入BUF的0020H偏移地址處(低位在前)。

解:(1)LEASI,BUF

MOVAX,[SI+4]

(2)SHRAX,1

SHRAX,1

。)MULWORDPTR6[SI]

(4)MOV2OH[S1]AX

MOV22H[SI],DX

13.設(shè)(BX)=11001011B,變量VAR的內(nèi)容為00110010B,求下列指令單獨執(zhí)行后BX的

內(nèi)容:

(1)XORBX,VAR;(2)ANDBX,VAR;

(3)ORBX,VAR;(4)XORBX,11110000B;

(5)ANDBX,00001111B;(6)TESTBX,1

解:(1)00F9H

(2)0002H

(3)00FBH

(4)003BH

(5)000BH

(6)00CBH

14.設(shè)(DX)=1O111O11B,(CL)=3,(CF)=1,求下列指令單獨執(zhí)行后DX的內(nèi)容:

(1)SHRDX,1;(2)SARDX,CL;(3)SHLDX,CL;

(4)SHI.DX,1;(5)RORDX,CL;(6)ROLDL,CL;

(7)SALDH,1;(8)RCLDX,CL;(9)RCRDL,1

解:DX=0000000010111011BCF=1CL=3

(1)SHRDX,DX邏輯右移10000000001011101B=005DH

(2)SARDX,CLDX算術(shù)右移3000000000001011IB=0017H

(3)SHLDX,CLDX邏輯左移30000010111011000B=05D8H

(4)SHI.DX,1DX邏輯左移10000000101110110B=0176H

(5)RORDX,CLDX循環(huán)右移301100000(X)01011IB=6017H

(6)ROLDL,CLDL循環(huán)左移30000000011011101B=00DDH

(7)SALDH,1DH算術(shù)左移1000000001011101IB=00BBH

(8)RCLDX,CLDX帶進(jìn)位循環(huán)左移30000010111011100B=05DCH

(9)RCRDL,1DL帶進(jìn)位循環(huán)右移10000000011011101B=00DDH

15.選擇題(各小題只有一個正確答案)

(1)執(zhí)行下列三條指令后:

MOVSP,1000H

PUSHAX

CALLBX

a.(SP)=1000H;b.(SP)=0FFEH;

c.(SP)=1004H;d.(SP)=0FFCH;

(2)要檢查寄存器AL中的內(nèi)容是否與AH相同,應(yīng)使用的指令為:

a.ANDAL,AHb.ORAL,AH

c.XORAL,AHd.SBBAL,AH

(3)指令JMPNEARPTRL1與CALLL1(LI為標(biāo)號)的區(qū)別在于:

a.尋址方式不同;b.是否保存IP的內(nèi)容;

c.目的地址不同;d.對標(biāo)志位的影響不同。

解:(1)DPUSHUAX則AX入棧,SP=0FFEH;CALLBX則IP入棧,SP=0FFCH

(2)C異或,若相同,則AL=0,ZF=lo

(3)B

16.寄存器DX:AX組成32位數(shù),DX為高位,編寫程序段實現(xiàn):

(1)DX:AX右移3位,并將移出的低3位保存在CL中;

(2)DX:AX左移3位,并將移出的高3位保存在CL中;

解:(1)移出的3位應(yīng)該按時序移入CL中。

XORCL,CL

MOVBL,3

LI:SHRDX,1

RCRAX,1

RCLCL,1

DECBL

JNZLI

(2)移出的3位應(yīng)該按時序移入CL中。

XORCL,CL

MOVBL,3

LI:SHLAX,1

RCLDX,1

RCLCL,1

DECBL

JNZL1

17.編寫程序段實現(xiàn)將BL中的每一位重復(fù)4次,構(gòu)成32位的雙字DX:AX,例如當(dāng)BL=

01011101B時,則得到的(DX)=0F0FH,(AX)=0FF0FHo

解:算術(shù)右移時,移入的值就是最高位本身,這樣可以使位內(nèi)容重復(fù),利用這一點可以實現(xiàn)

題目的要求。

XORDX,DX

XORAX,AX

MOVCX,4

LI:SHRBL,1

RCRAX,1

SARAX,1

SARAX,1

SARAX,1

LOOPLI

MOVCX,4

L2:SHRBL,1

RCRDX,!

SARDX,1

SARDX,1

SARDX,1

LOOPL2

18.字變量VAR1中保存有小于38250的16位無符號數(shù),編寫程序段實現(xiàn)VAR1:150,并

進(jìn)行四舍五入操作,將商保存在字節(jié)變量VAR2中。

解:根據(jù)題意,38250-150=255,因此商不會超過255,可以用一個字節(jié)表示。

a+b的四舍五入操作可以通過判斷除后余數(shù)實現(xiàn):余數(shù)大于等于除數(shù)的一半,則商加1;

否則不用加1。但這種方法用匯編語言編程實現(xiàn)時比較復(fù)雜,這里介紹另外一種方法:設(shè)a

小b的四舍五入后的結(jié)果為c,用『』表示取整數(shù)操作,則

無+用空

這種方法是在除法操作之前,在被除數(shù)上加上除數(shù)的一半,這樣除法操作后得到的值就是考

慮了四舍五入的商。

VARIDW12345

VAR2DB?

DATAADB150

MOVAX,VARI

XORBX,BX

MOVBL,DATAA

SHRBX,1

ADDAX,BX

DIVDATAA

MOVVAR2,AL

19.有一組無符號的16位數(shù)據(jù)保存在BUFFER中,前兩個字節(jié)存放數(shù)據(jù)的個數(shù),編程實現(xiàn)

按下式進(jìn)行濾波處理:

y(k)=k)+x(k-1)4-x(k-2))k>2

y(k)=x(k)k<2

解:濾波結(jié)果保存在FILT中。

BUFFERDWOCH

DW33H,18H,1BH,06H,33H,08H

DW3H,6H,OFH,51H,05H,OCH

F1LTDW100HDUP(?)

LEASI,BUFFER

LEADT,FILT

MOVCX,[SI]

ADDSI,2

MOVAX,[SljAX=X1

MOV[DI],AX

MOVBX,2(S1]

MOV2[DI],BX

ADDSI,4

ADDDI,4

DECCX

DECCX

ADDAX,BX

XORDX,DX

ADCDX,0

MOVBX,3

LI:

ADDAX,[SI]

ADCDX,0

PUSHDX

PUSHAX

DTVBX

MOV[DI],AX

POPAX

POPDX

SUBAX,[ST-4]

SBBDX,0

ADDDI,2

ADDSI,2

LOOPLI

20.在由字符串構(gòu)成的緩沖區(qū)BUFFER中,前2個字節(jié)存放字符個數(shù),后續(xù)每個字節(jié)存放

一個字符的ASCII碼。編寫程序?qū)崿F(xiàn)將字符串‘2004’替換成‘2006'。

解:在數(shù)據(jù)段中定義:

BUFFERDW74

DB'Thisyearis2004.In2004,wehaveaplanforreducingannualexpensive10%’

DESTDB'2004'

在代碼段中編寫程序段:

CLD

LEAsi,BUFFER

MOVCX,[SI]

ADDsi,2

LEADI,DEST

LI:PUSHSI

PUSHDI

PUSHCX

MOVCX,4

REPZCMPSB

JNZL2

MOVBYTEPTR[SL1]/6’

L2:POPCX

POPDI

POPSI

INCSI

INCDI

LOOPLI

21.定義有下列宏指令:

WAGSMACROS1,S2,S3

SUBAX,AX

MOVDXAX

ADDAX,SI

/\DDAX,S2

ADCDX,0

ADDAX,S3

ADCDX,0

ENDM

當(dāng)采用宏調(diào)用指令“WAGS60000,25000,3000”時,執(zhí)行后DX=AX=。

解:宏指令WAGS完成的功能為S1+S2+S3,結(jié)果放在DX:AX中。所以,調(diào)用“WAGS

60000,25000,3000"時,其結(jié)果為DX=0001H,AX=57C0H

22.對上題定義的宏指令,如果采用宏調(diào)用指令"WAGSBX,CX,SI”時,寫出宏展開形式。

解:調(diào)用“AGSBX,CX,SI”時,宏展開形式:

SUBAX,AX

MOVDX,AX

ADDAX,BX

ADDAX,CX

ADCDX,0

ADDAX,SI

ADCDX,0

23.寫出宏指令SUMMING,實現(xiàn)將字節(jié)緩沖區(qū)array中的內(nèi)容求校驗和(保留低8位),并

保存在VALUE中。

解:設(shè)array前兩個字節(jié)保存緩沖區(qū)字節(jié)數(shù),在宏指令SUMMING,將array和VALUE作為

形式參數(shù)。

SUMMINGMACROarray,VAI.UE

LEASI,array

MOVCX,[SI]

ADDSI,2

XORAL,AL

ADDAL,[SI]

INCSI

LOOPLI

MOVVALUEAL

ENDM

第4章匯編語言程序設(shè)計

1.已知在BUF的起始處保存有N個字符的ASCII碼,編寫匯編語言程序?qū)崿F(xiàn),將這組字

符串傳送到緩沖區(qū)BUFR中,并且使字符串的順序與原來的順序相反。

解:BUFDB"BONJOUR_BELLE"

BUFRDB100DUP(?)

MOVCX,N

LEASI,BUF

LEADI,BUFR

ADDDI,CX

DECDI

LI:

MOVAL,[SI]

MOV[DI],AL

INCSI

DECDI

LOOPLI

2.利用移位、傳送和相加指令實現(xiàn)AX的內(nèi)容擴大10倍。

解:將擴大后的結(jié)果放在DX:AX中,注意到10XAX=8XAX+2XAX。

XORDX,DX

SHLAX,1

RCLDX,1

MOVBXAX

MOVCX,DX

SHLAX,1

RCLDX,1

SHLAX,1

RCLDX,1

ADDAX,BX

ADCDX,CX

3.在緩沖區(qū)VAR中連續(xù)存放著3個16位的無符號數(shù),編寫程序?qū)崿F(xiàn)將其按遞增關(guān)系排列;

如果VAR中保存的為有符號數(shù),則再編寫程序?qū)崿F(xiàn)將其按遞減關(guān)系排列。

解:VARDW1236,-432,3900

XORSI?SI

MOVAX,VAR[SI]

CMPAX,VAR[SI+2]

JAELI

XCHGAX,VAR[SI+2]

LI:

CMPAX,VAR[SI+4]

JAEL2

XCHGAX,VAR[SI+4]

L2:

MOVVAR[SI],AX

MOVAX,VAR[SI+2]

CMPAX,VAR[SI+4]

JAEL3

XCHGAX,VAR[SI+4]

L3:

MOVVAR[SI+2],AX

4.編寫程序段實現(xiàn)將AL和BL中的每一位依次交叉,得到的16位字保存在DX中,例如

(AL)=O11OO1O1B,(BL)=11O11O1OB,則得到的(DX)=1011011010011001BO

解:利用移位指令完成。

XORDX,DX

MOVCX,8

LI:

SHRAL,1

RCRDX,1

SHRBL,1

RCRDX,1

LOOPLI

5.在變量VARI和VAR2中分別保存有兩個字節(jié)型的正整數(shù),編寫完整的匯編語言程序?qū)?/p>

現(xiàn):

(1)當(dāng)兩數(shù)中有一個奇數(shù)時,將奇數(shù)存入VAR1,偶數(shù)存入VAR2;

(2)當(dāng)兩數(shù)均為奇數(shù)時,兩個變量的內(nèi)容不變;

(3)當(dāng)兩數(shù)均為偶數(shù)時,兩數(shù)縮小一倍后存入原處。

解:當(dāng)VAR1為奇數(shù)時,不論VAR2的奇偶性,這兩個單元的內(nèi)容均不變;只有當(dāng)VAR1

為偶數(shù)時,如果VAR2為奇數(shù),則VAR1與VAR2內(nèi)容交換;如果VAR2為偶數(shù),則兩數(shù)縮

小一倍后存入原處。

DATASEGMENT

VARIDB28

VAR2DB36

DATAENDS

CODESEGMENT

ASSUMECS:CODE,DS:DATA,ES:DATA

START:

MOVAX,DATA

MOVDS,AX

MOVES,AX

MOVAL,VARI

MOVBL,VAR2

TESTAL,1

JZEVEN1

JMPOVER

EVEN1:

TESTBL,1

JZEVEN2

MOVVARI,BL

MOVVAR2AL

JMPOVER

EVEN2:

SHRAL,1

MOVVARIAL

SHRBL,1

MOVVAR2,BL

OVER:

MOVAH,4CH

MOVAL,0

1NT21H

CODEENDS

ENDSTART

6.已知在字變量VARI、VAR2和VAR3中保存有3個相同的代碼,但有一個錯碼,編寫

程序段找出這個錯碼,并將它送到AX,其地址送SI;如果3個代碼都相同,則在AX

中置一1標(biāo)志。

解:在數(shù)據(jù)段中定義:

VAR1DW5A34H

VAR2DW5A35H

VAR3DW3A34H

在代碼段中編寫程序段:

MOVAX,-1

MOVBX,VAR1

CMPBX,VAR2

JZL2

CMPBX,VAR3

JZLI

MOVAX,BX

LEASI,VARI

JMPOVER

LI:

MOVAX,VAR2

LEASI,VAR2

JMPOVER

L2:

CMPBX,VAR3

JZOVER

MOVAX,VAR3

LEAS1,VAR3

OVER:

7.分析下列程序段的功能:

MOVCL,04

SHLDX,CL

MOVBL,AH

SHLAX,CL

SHRBL,CL

ORDL,BL

解:程序段完成DX:AX組成的32位無符號數(shù)左移4位,低位補零(也即除以16)。

8.下列程序段執(zhí)行后,求BX寄存器的內(nèi)容:

MOVCL,3

MOVBX,0B7H

ROLBX,1

RORBX,CL

解:實際上完成BX內(nèi)容循環(huán)右移2位,因此,BX寄存器的內(nèi)容為C02DH。

9.下列程序段執(zhí)行后,求BX寄存器的內(nèi)容:

MOVCL,5

MOVBX,7D5CH

SHRBX,CL

解:完成BX內(nèi)容邏輯右移5位,因此,BX寄存器的內(nèi)容為03EAH。

10.將BUFFERS中N個字按相反順序傳遞到BUFFERT中。

解:

LEASI,BUFFERS

LEADI,BUFFERT

MOVCXN

ADDDI,N

ADDDI,N

SUBDI,2

LI:

MOVAX,[ST]

MOV[Dll,AX

ADDSI,2

SUBDI2

LOOPLI

11.數(shù)組ARRAY中存放有一組字型數(shù)據(jù),前兩個字節(jié)存放數(shù)據(jù)長度(5的倍數(shù))。為給這個

數(shù)組中的數(shù)據(jù)進(jìn)行加密保護(hù),每5個數(shù)據(jù)取出一個數(shù)據(jù)進(jìn)行加密處理:奇數(shù)位進(jìn)行取反,

偶數(shù)位不變,例如對數(shù)據(jù)0110110010110001B加密后變成1100011000011011B,編寫

加密程序encrpytion和解密程序unencrpytion。

解:約定從第一個數(shù)據(jù)開始,每5個數(shù)據(jù)為一組,每組中的第一個數(shù)據(jù)采取加密/解密處理。

由于加密算法采用的是取反操作,解密算法也采用取反操作,因此解密和解密算法是同一個

程序。

ENCRPYTIONPROCNEAR

LEASI,ARRAY

XORDX,DX

MOVAX,[SI]

MOVBX,5

DIVBX

MOVCX,AX

ADDSI,2

LI:

MOVAX,[SI]

XORAX,0AAAAH

MOV[SI],AX

ADDSI,10

LOOPLI

RET

ENCRPYT1ONENDP

13.設(shè)BUF中存放有N個無符號數(shù)(或有符號數(shù)),編程實現(xiàn)求它們的最小值(存入AX)

和最大值(存入DX)。

解:BUF存放有N個無符號數(shù)的程序如下:

MOVCX,N

LEASI,BUF

MOVAX,[SI]

MOVDXAX

ADDSI,2

LI:

CMPAX,[SI]

JBENOCHG1

XCHGAX,[SI]

NOCHG1:

CMPDX,[SI]

JAENOCHG2

XCHGDX,[SI]

NOCHG2:

ADDSI,2

LOOPLI

如果BUF中存放的是有符號數(shù),則只需要將程序中的兩行內(nèi)容修改:

JBENOCHG1改成:JLENOCHG1

JAENOCHG2改成:JGENOCHG2

14.設(shè)BUFFER中存放有N個無符號(第1個字節(jié)存放緩沖區(qū)的長度),編程實現(xiàn)將其中的

0元素抹去,并更新其長度。

解:設(shè)BUFFER中存放的是字節(jié)型數(shù)據(jù)。采用雙指針方法:SI為讀指針,DI為寫指針,

從低地址開始,內(nèi)存中讀出一個字節(jié),如果不為3則寫入內(nèi)存;如果為0,則不進(jìn)行寫操

作。

LEASI,BUFFER

XORCX,CX

MOVCL,[SI]

INCSI

MOVDI,SI

XORBH,BH

XORAL,AL

LI:

CMP[SI],AL

JZL2

MOVBL,[SI]

MOV[DI],BL

INCDI

INCBH

L2:

INCST

LOOPLI

MOVBUFFER,BH

16.編寫一個子程序?qū)崿F(xiàn)統(tǒng)計AL中1的個數(shù),然后檢測出字節(jié)型緩沖區(qū)BUF中0和1個

數(shù)相等的元素個數(shù)。

解:統(tǒng)計AL中1的個數(shù),只需將AL右移,移出的一位內(nèi)容進(jìn)行累加,子程序為:

COUNTBYTEPROCNEAR

PUSHAX

PUSHCX

MOVCX,8

XORBL,BL

COUI:

SHRAL,1

ADCBL,0

LOOPCOUI

POPCX

POPAX

RET

COUNTBYTEENDP

在此基礎(chǔ)上,可以檢測出字節(jié)型緩沖區(qū)BUF中0和1個數(shù)相等的元素個數(shù),即一個字

節(jié)中有4個1。設(shè)BUF中有N個字節(jié)型數(shù)據(jù),結(jié)果保持在BH中。

MOVCX,N

LEASI,BUF

XORBH,BH

LI:MOVAL,[SI]

CALLCOUNTBYTE

CMPBL,4

JNZL2

INCBH

L2:INCSI

LOOPLI

19.在緩沖區(qū)BUFFER中,第1個字節(jié)存放數(shù)組的長度(〈256),從第2個字節(jié)開始存放字

符的ASCII碼,編寫子程序完成在最高位給字符加上偶校驗°

解:STACKSEGMENTSTACKSTACK'

DW100HDUP(?)

TOPLABELBYTE

STACKENDS

DATASEGMENT

BUFFERDB3;首字節(jié)為字符串長度

DB,ABC;字符串

DATAENDS

CODESEGMENT

ASSUMECS:CODE,DS:DATA,ES:DAT;\,SS:STAC1<

START:

MOVAX,STACK

MOVSS,AX

LEASP,TOP

MOVAX,DATA

MOVDS,AX

MOVES,AX

LEADI,BUFFER

XORCX,CX

MOVCL,[DI]

INCDI

CALLSETEVEN

MOVAH,4CH;返回DOS

MOVAL,0

INT21H

SETEVENPROCNEAR;加偶校驗子程序

PUSHAX

PUSHBX

PUSHCX

PUSHDI

SETEVEN1:

MOVAL,[DI]

CALLCOUNTBYTE

ANDBL,01H

JZSETEVEN2

ORAL,80H

MOV[DI],AL

SETEVEN2:

INCDI

LOOPSETEVEN1

POPDI

POPex

POPBX

POPAX

RET

SETEVENENDP

COUNTBYTEPROCNEAR

PUSHAX

PUSHCX

MOVCX,8

XORBL,BL

COUI:

SHRAL,1

ADCBL,0

LOOPCOUI

POPCX

POPAX

RET

COUNTBYTEENDP

CODEENDS

ENDSTART

20.編寫程序完成求多位數(shù)(N個字)的絕對值。

21.已知斐波那契數(shù)列的定義為:=1,F2=1,F=F_,+F_2(i>3),編寫求該

數(shù)列前n項的子程序。

解:設(shè)獎斐波那契數(shù)列存放在字變量RESULT中。在數(shù)據(jù)段中定義

RESULTDW100HDUP(?)

在代碼段中編寫子程序

FIBONACCIPROCNEAR

XORDT,DI

MOVRESULT[D1],1;前兩個數(shù)為1

MOVRESULT[DI+2],1

ADDDI,4

MOVCX,N

LI:

MOVAX,RESULT[DL4]

ADDAX,RESULT[DI-2]

MOVRESULT[DI],AX

ADDDI,2

LOOPLI

RET

FIBONACCIENDP

22.編寫程序?qū)崿F(xiàn)循環(huán)顯示10條信息,保存每條信息的變量分別為INFQM1?INFQRM10。

解:在數(shù)據(jù)段中定義變量:

TABLEDWINFORM1,INFORM2,INFORM3,INFORM4,INFORMS

DWINFORM6,INFORM7,INFORMS,INFORM9,INFORMIO

在代碼段中編寫程序段:

MOVCX,10

XORSI,si

LI:MOVDX,TABLE[S1]

MOVAH,9

INT21H

ADDSI,2

CALLWAIT

LOOPLI

這里,WAIT為延時子程序,用于在顯示信息之間的停頓。

23.編寫程序?qū)崿F(xiàn)將包含20個數(shù)據(jù)的數(shù)組ARRAY分成兩個數(shù)組:正數(shù)數(shù)組ARRAYP和負(fù)

數(shù)數(shù)組ARRAYN,并分別將這兩個數(shù)組中數(shù)據(jù)的個數(shù)顯示出來。

解:先編寫一個子程序DISPALD,完成以3位十進(jìn)制數(shù)形式顯示出AL的內(nèi)容。

DISPALDPROCNEAR

PUSHAX

PUSHCX

溫馨提示

  • 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)確性、安全性和完整性, 同時也不承擔(dān)用戶因使用這些下載資源對自己和他人造成任何形式的傷害或損失。

最新文檔

評論

0/150

提交評論