新聞中心

EEPW首頁 > 嵌入式系統(tǒng) > 設(shè)計應(yīng)用 > 51單片機教程:單片機數(shù)據(jù)傳送類指令

51單片機教程:單片機數(shù)據(jù)傳送類指令

作者: 時間:2012-06-15 來源:網(wǎng)絡(luò) 收藏

設(shè)R0中的值為2,送入A中,而DPTR中的值則為TABLE,則最終確定的ROM單元的地址就是TABLE+2,也就是到這個單元中去取數(shù),取到的是4,顯然它正是2的平方。其它也能類推。

標(biāo)號的真實含義:從這個地方也能看到另一個問題,我們使用了標(biāo)號來替代具體的單元地址。事實上,標(biāo)號的真實含義就是地址數(shù)值。在這里它代表了,0,1,4,9,16,25這幾個在ROM中存放的起點位置。而在以前我們學(xué)過的如LCALL DELAY中,DELAY 則代表了以DELAY為標(biāo)號的那段程序在ROM中存放的起始地址。事實上,CPU正是通過這個地址才找到這段程序的。

能通過以下的例程再來看一看標(biāo)號的含義:

MOV DPTR,#100H

MOV A,R0

MOVC A,@A+DPTR

ORG 0100H.

DB 0,1,4,9,16,25

如果R0中的值為2,則最終地址為100H+2為102H,到102H單元中找到的是4。這個能看懂了吧?

那為什么不這樣寫程序,要用標(biāo)號呢?不是增加疑惑嗎?

如果這樣寫程序的話,在寫程序時,我們就必須確定這張表格在ROM中的具體的位置,如果寫完程序后,又想在這段程序前插入一段程序,那么這張表格的位置就又要變了,要改ORG 100H這句話了,我們是經(jīng)常需要修改程序的,那多麻煩,所以就用標(biāo)號來替代,只要一編譯程序,位置就自動發(fā)生變化,我們把這個麻煩事交給計算機#0;#0;指我們用的電腦去做了。

堆棧操作

PUSH direct

POP direct

第一條稱之為推入,就是將direct中的內(nèi)容送入堆棧中,第二條稱之為彈出,就是將堆棧中的內(nèi)容送回到direct中。推入指令的執(zhí)行過程是,首先將SP中的值加1,然后把SP中的值當(dāng)作地址,將direct中的值送進以SP中的值為地址的RAM單元中。例:

MOV SP,#5FH

MOV A,#100

MOV B,#20

PUSH ACC

PUSH B

則執(zhí)行第一條PUSH ACC指令是這樣的:將SP中的值加1,即變?yōu)?0H,然后將A中的值送到60H單元中,因此執(zhí)行完本條指令后, 內(nèi)存60H單元的值就是100,同樣,執(zhí)行PUSH B時,是將SP+1,即變?yōu)?1H,然后將B中的值送入到61H單元中,即執(zhí)行完本條指令后,61H單元中的值變?yōu)?0。

POP指令的在中執(zhí)行是這樣的,首先將SP中的值作為地址,并將此地址中的數(shù)送到POP指令后面的那個direct中,然后SP減1。

接上例:

POP B

POP ACC

則執(zhí)行過程是:將SP中的值(現(xiàn)在是61H)作為地址,取61H單元中的數(shù)值(現(xiàn)在是20),送到B中,所以執(zhí)行完本條指令后B中的值是20,然后將SP減1,因此本條指令執(zhí)行完后,SP的值變?yōu)?0H,然后執(zhí)行POP ACC,將SP中的值(60H)作為地址,從該地址中取數(shù)(現(xiàn)在是100),并送到ACC中,所以執(zhí)行完本條指令后,ACC中的值是100。

這有什么意義呢?ACC中的值本來就是100,B中的值本來就是20,是的,在本例中,的確沒有意義,但在實際工作中,則在PUSH B后一般要執(zhí)行其他指令,而且這些指令會把A中的值,B中的值改掉,所以在程序的結(jié)束,如果我們要把A和B中的值恢復(fù)原值,那么這些指令就有意義了。

還有一個問題,如果我不用堆棧,比如說在PUSH ACC指令處用MOV 60H,A,在PUSH B處用指令MOV 61H,B,然后用MOV A,60H,MOV B,61H來替代兩條POP指令,不是也一樣嗎?是的,從結(jié)果上看是一樣的,但是從過程看是不一樣的,PUSH和POP指令都是單字節(jié),單周期指令,而MOV指令則是雙字節(jié),雙周期指令。更何況,堆棧的作用不止于此,所以一般的計算機上都設(shè)有堆棧,也是一樣,而我們在編寫子程序,需要保存時,常常也不采用后面的辦法,而是用堆棧的辦法來實現(xiàn)。



評論


相關(guān)推薦

技術(shù)專區(qū)

關(guān)閉