大綜合課件微機原理上課基礎(chǔ)_第1頁
大綜合課件微機原理上課基礎(chǔ)_第2頁
大綜合課件微機原理上課基礎(chǔ)_第3頁
大綜合課件微機原理上課基礎(chǔ)_第4頁
大綜合課件微機原理上課基礎(chǔ)_第5頁
已閱讀5頁,還剩30頁未讀, 繼續(xù)免費閱讀

下載本文檔

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

文檔簡介

12.1符號指令中的表達(dá)式1.常量和數(shù)值表達(dá)式;2.變量和地址表達(dá)式;3.標(biāo)號;4.標(biāo)量和標(biāo)號類型的變更。22.變量和地址表達(dá)式變量是存儲器中的數(shù)據(jù)或數(shù)據(jù)區(qū)的符號表示。變量名即是數(shù)據(jù)的地址或數(shù)據(jù)區(qū)的首地址。地址表達(dá)式是由變量、常量、寄存器(SI、DI、BX、BP)的內(nèi)容和運算符組成的有意義的式子。變量或地址表達(dá)式可給出指令中的存儲器的地址。由于存儲器是分段使用的,因此變量或地址表達(dá)式都具有3重屬性:段地址、偏移地址和類型。3變量的段地址是指變量所在段的段首地址除以10H之商;變量的偏移地址是指變量所在段的段首址到該變量的字節(jié)距離;變量的段地址和偏移地址分別用SEG或OFFSET兩個算符來指定。例如:變量W的段地址和偏移地址分別表示為SEGW和OFFSETW。

4變量的定義[變量名]

數(shù)據(jù)定義偽指令表達(dá)式[,……]

變量名:數(shù)據(jù)的地址或數(shù)據(jù)區(qū)的首地址數(shù)據(jù)定義偽指令:DB(定義字節(jié))、DW(定義字)、DD(定義雙字)、DQ(定義4字)、DT(定義10字節(jié))表達(dá)式:數(shù)值表達(dá)式、ASCII碼字符串、地址表達(dá)式、?及nDUP(表達(dá)式)5

例如,在數(shù)據(jù)段DATAl中定義的變量如下:

WlDWB3;

B1DB'AB$’;

W2DW-5,1994H;

B2DB4DUP(?);

DDDEB;

B3DB2DUP(-1)DB1DUP(10,’E’);

DB’13’,1,3在附加數(shù)據(jù)段DATA2中定義的變量如下:

EBDB8DUP(?)EWDW’AB’,’CD’

64.標(biāo)量和標(biāo)號類型的變更格式:類型PTR地址表達(dá)式PTR算符用來明確指出某個變量、標(biāo)號或地址表達(dá)式的類型屬性,或者使它們臨時兼有與原定義所不同的類型屬性,但仍保持它們原來的段地址和偏移地址屬性不變。如:BYTEPTRW1

7尋址方式——尋找操作數(shù)的方法

尋找操作數(shù)的地址在8086指令系統(tǒng)中,說明操作數(shù)所在地址的尋址方式可分為8種:

①立即尋址⑤寄存器相對尋址

②直接尋址⑥基址-變址尋址

③寄存器尋址⑦相對的基址-變址尋址

④間接尋址⑧隱含尋址三、8086的尋址方式8寄存器間接、寄存器相對、基址變址、相對基址變址四種尋址方式的比較:

尋址方式指令操作數(shù)形式

寄存器間接——只有一個寄存器(BX/BP/SI/DI之一)寄存器相對——一個寄存器加上位移量基址—變址——兩個不同類別的寄存器相對基址-變址——兩個不同類別的寄存器加上位移量92.38086/8088指令系統(tǒng)

數(shù)據(jù)傳送類指令加減運算指令位操作指令指令應(yīng)用舉例102.3.1數(shù)據(jù)傳送類指令

可實現(xiàn)存儲器寄存器I/O

數(shù)據(jù)傳送指令又可分為如下四種:數(shù)據(jù)傳送指令數(shù)據(jù)交換指令堆棧操作指令地址傳送指令查表轉(zhuǎn)換指令111.數(shù)據(jù)傳送指令(1)MOVdest,src;dest←src

傳送的是字節(jié)還是字取決于指令中涉及的寄存器是8位還是16位。具體來說可實現(xiàn):

①MOVmem/reg1,mem/reg2

指令中兩操作數(shù)中至少有一個為寄存器例:MOV CL,DLMOV AX,BX MOV [SI],CX

MOV CL,[BX+5]12MOV指令使用規(guī)則:1)IP不能作目的寄存器2)不允許mem←mem3)不允許segreg←segreg4)立即數(shù)、CS不允許作為目的操作數(shù)5)不允許segreg←立即數(shù)6)源操作數(shù)與目的操作數(shù)類型要一致13應(yīng)用舉例:將1000H開始的100個存儲單元全部填充為ASCII碼2AH(*)。程序段如下:

MOVDI,1000HMOVCX,64HMOVAL,2AHAGAIN:MOV[DI],ALINCDI

DECCXJNZAGAINHLT14格式:XCHGreg,mem/reg功能:交換兩操作數(shù)的內(nèi)容。要求:兩操作數(shù)中必須有一個在寄存器中;操作數(shù)不能為段寄存器和立即數(shù);源和目地操作數(shù)類型要一致。舉例:XCHG AX,BXXCHG [2000],CL(2)數(shù)據(jù)交換指令XCHG15什么是堆棧?按“后進(jìn)先出(LIFO)”方式工作的存儲區(qū)域。堆棧以字為單位進(jìn)行壓入彈出操作。為什么要設(shè)置堆棧?為什么要按“后進(jìn)先出”方式工作?參見下圖(3)堆棧操作指令16堆棧指令使用時應(yīng)注意幾點:①堆棧操作總是按字進(jìn)行②不能從棧頂彈出一個字給CS③堆棧指針為SS:SP,SP永遠(yuǎn)指向棧頂④SP自動進(jìn)行增減量(-2,+2)17(4)地址傳送指令用途:用于傳送操作數(shù)的地址傳送偏移地址格式:LEAreg,mem;將指定內(nèi)存單元的偏移地址送到指定寄存器傳送地址指針格式:LDSreg,mem32;DS:reg←(mem開始的四個內(nèi)存單元的內(nèi)容)LESreg,mem32;同上,但DS改為ES要求:

1)源操作數(shù)必須是一個存儲器操作數(shù);

2)目的操作數(shù)必須是一個16位的通用寄存器。18(5)查表指令XLAT

執(zhí)行的操作:AL←[(BX)+(AL)]

又叫查表轉(zhuǎn)換指令,它可根據(jù)表項序號查出表中對應(yīng)代碼的內(nèi)容。執(zhí)行時先將表的首地址(偏移地址)送到BX中,表項序號存于AL中。

例如:內(nèi)存數(shù)據(jù)段有一張16進(jìn)制數(shù)的ASCII碼表,設(shè)首地址為2000H,如欲查出表中第11個代碼(代碼序號從0開始)即十六進(jìn)制數(shù)B的ASCII碼。ASCII表在DS段中,并假設(shè)(DS)=4000H。見下頁圖。192.3.2加減運算指令1.加法指令2.減法指令

3.比較指令20(1)不帶進(jìn)位的加法指令A(yù)DD

格式:ADD acc,dataADD mem/reg,dataADD

mem/reg1,mem/reg2

實例:

ADD AL,30HADD SI,[BX+20H] ADD CX,SI ADD [DI],200H1.加法指令21(2)帶進(jìn)位位的加法指令A(yù)DCADC指令在形式上和功能上與ADD類似,只是相加時還要包括進(jìn)位標(biāo)志CF的內(nèi)容,例如:

ADCAL,68H;AL←(AL)+68H+(CF) ADCAX,CX;AX←(AX)+(CX)+(CF)ADCBX,[DI];BX←(BX)+[DI+1][DI]+(CF)22格式:INCreg/mem功能:類似于C語言中的++操作:對指定的操作數(shù)加1例:INCALINCSIINCBYTEPTR[BX+4]注:本指令不影響CF標(biāo)志。3)加1指令I(lǐng)NC(增量指令)(單操作數(shù)指令)23(1)不考慮借位的減法指令SUB

格式:SUBdest,src

操作:dest←(dest)-(src)注:1.源和目的操作數(shù)不能同時為存儲器操作數(shù)

2.立即數(shù)不能作為目的操作數(shù)指令例子:

SUBAL,60HSUB[BX+20H],DXSUBAX,CX2.減法指令24SBB指令主要用于多字節(jié)的減法。格式:SBBdest,src操作:dest←(dest)-(src)-(CF)指令例子:

SBBAX,CXSBBWORDPTR[SI],2080HSBB[SI],DX(2)考慮借位的減法指令SBB25作用類似于C語言中的“--”操作符。格式:DECopr 操作:opr←(opr)-1指令例子:

DECCLDECBYTEPTR[DI+2]DECSI(3)減1指令DEC(減量指令)26格式:CMPdest,src操作:(dest)-(src)CMP也是執(zhí)行兩個操作數(shù)相減,但結(jié)果不送目標(biāo)操作數(shù),其結(jié)果只反映在標(biāo)志位上。指令例子:

CMPAL,0AHCMPCX,SICMPDI,[BX+03]3.比較指令CMP272.3.3位操作指令:邏輯運算和位移指令

1.邏輯運算指令●運算規(guī)則:按位操作,無進(jìn)/借位

●對標(biāo)志位的影響(除NOT指令外):CFOFSFZFPFAF00***無定義

根據(jù)運算結(jié)果設(shè)置28格式:NEGopr操作:opr←0-(opr)對一個操作數(shù)取補,可將該數(shù)變?yōu)榻^對值相等符號相反的另一數(shù)。例:若(AL)=0FCH,則執(zhí)行NEGAL 后,

(AL)=04H本例中,0FCH可視為-4的補碼,執(zhí)行求補指令后,即得到4(-4的絕對值)。(1)求補指令NEG29(2)邏輯”與”AND對兩個操作數(shù)進(jìn)行按位邏輯“與”操作。格式:ANDdest,src用途:保留操作數(shù)的某幾位,清零其他位。例1:保留AL中低4位,高4位清0。

ANDAL,0FH例2:AL中有字符’a’~’z’,將其轉(zhuǎn)換成大寫。

ANDAL,01011111B;30對兩個操作數(shù)進(jìn)行按位邏輯”或”操作。格式:ORdest,src用途:對操作數(shù)的某幾位置1;對兩操作數(shù)進(jìn)行組合。例1:把AL中的非壓縮BCD碼變成相應(yīng)十進(jìn)制數(shù)的ASCII碼。

ORAL,30H(3)邏輯”或”O(jiān)R31對操作數(shù)進(jìn)行按位邏輯”非”操作(包括符號位)。格式:NOTmem/reg例:NOTCXNOTBYTEPTR[DI](4)邏輯“非”(取反)NOT32對兩個操作數(shù)按位進(jìn)行”異或”操作。格式:XORdest,src用途:對reg清零(自身異或)

把reg/mem的某幾位變反(與’1’異或)例1:把AX寄存器清零。例2:把DH的bit4,3變反①MOVAX,0XORDH,18H②XORAX,AX③ANDAX,0④SUBAX,AX(5)邏輯”異或”XOR

33操作與AND指令類似,但不將”與”的結(jié)果送回,只影響標(biāo)志位。TEST指令常用于位測試,與條

溫馨提示

  • 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

提交評論