<meter id="pryje"><nav id="pryje"><delect id="pryje"></delect></nav></meter>
          <label id="pryje"></label>

          新聞中心

          EEPW首頁(yè) > 嵌入式系統(tǒng) > 設(shè)計(jì)應(yīng)用 > MCS-51單片機(jī)匯編指令詳解

          MCS-51單片機(jī)匯編指令詳解

          作者: 時(shí)間:2016-12-01 來(lái)源:網(wǎng)絡(luò) 收藏
          以累加器為目的操作數(shù)的指令

                MOV A,Rn

          本文引用地址:http://www.ex-cimer.com/article/201612/324581.htm

                MOV A,direct

                MOV A,@Ri

                MOV A,#data

            第一條指令中,Rn代表的是R0-R7。第二條指令中,direct就是指的直接地址,而第三條指令中,就是我們剛才講過的。第四條指令是將立即數(shù)data送到A中。

          下面我們通過一些例子加以說(shuō)明:

                MOV A,R1 ;將工作寄存器R1中的值送入A,R1中的值保持不變。

                MOV A,30H ;將內(nèi)存30H單元中的值送入A,30H單元中的值保持不變。

                MOV A,@R1 ;先看R1中是什么值,把這個(gè)值作為地址,并將這個(gè)地址單元中的值送入A中。如執(zhí)行命令前R1中的值為20H,則是將20H單元中的值送     入A中。

                MOV A,#34H ;將立即數(shù)34H送入A中,執(zhí)行完本條指令后,A中的值是34H。

              以寄存器Rn為目的操作的指令

                MOV Rn,A

                MOV Rn,direct

                MOV Rn,#data

                這組指令功能是把源地址單元中的內(nèi)容送入工作寄存器,源操作數(shù)不變。

              以直接地址為目的操作數(shù)的指令

                MOV direct,A 例: MOV 20H,A

                MOV direct,Rn MOV 20H,R1

                MOV direct1,direct2 MOV 20H,30H

                MOV direct,@Ri MOV 20H,@R1

                MOV direct,#data MOV 20H,#34H

              以間接地址為目的操作數(shù)的指令

                MOV @Ri,A 例:MOV @R0,A

                MOV @Ri,direct MOV @R1,20H

                MOV @Ri,#data MOV @R0,#34H

              十六位數(shù)的傳遞指令

                MOV DPTR,#data16

                8051是一種8位機(jī),這是唯一的一條16位立即數(shù)傳遞指令,其功能是將一個(gè)16位的立即數(shù)送入DPTR中去。其中高8位送入 DPH(083H),低8位送入DPL(082H)。例:MOV DPTR,#1234H,則執(zhí)行完了之后DPH中的值為12H,DPL中的值為34H。反之,如果我們分別向DPH,DPL送數(shù),則結(jié)果也一樣。如有下面兩條指令:MOV DPH,#35H,MOV DPL,#12H。則就相當(dāng)于執(zhí)行了MOV DPTR,#3512H。

              累加器A與片外RAM之間的數(shù)據(jù)傳遞類指令

                MOVX A,@Ri

                MOVX @Ri,A

                MOVX #9; A,@DPTR

                MOVX @DPTR,A

          說(shuō)明:

                1)在51中,與外部存儲(chǔ)器RAM打交道的只可以是A累加器。所有需要送入外部RAM的數(shù)據(jù)必需要通過A送去,而所有要讀入的外部RAM中的數(shù)據(jù)也必需通過A讀入。在此我們可以看出內(nèi)外部RAM的區(qū)別了,內(nèi)部RAM間可以直接進(jìn)行數(shù)據(jù)的傳遞,而外部則不行,比如,要將外部RAM中某一單元(設(shè)為 0100H單元的數(shù)據(jù))送入另一個(gè)單元(設(shè)為0200H單元),也必須先將0100H單元中的內(nèi)容讀入A,然后再送到0200H單元中去。

                2)要讀或?qū)懲獠康腞AM,當(dāng)然也必須要知道RAM的地址,在后兩條指令中,地址是被直接放在DPTR中的。而前兩條指令,由于Ri(即R0或 R1)只是一個(gè)8位的寄存器,所以只提供低8位地址。因?yàn)橛袝r(shí)擴(kuò)展的外部RAM的數(shù)量比較少,少于或等于256個(gè),就只需要提供8位地址就夠了。

                3)使用時(shí)應(yīng)當(dāng)首先將要讀或?qū)懙牡刂匪腿隓PTR或Ri中,然后再用讀寫命令。

                例:將外部RAM中100H單元中的內(nèi)容送入外部RAM中200H單元中。

                  MOV DPTR,#0100H

                  MOVX A,@DPTR

                  MOV DPTR,#0200H

                  MOVX @DPTR,A

              程序存儲(chǔ)器向累加器A傳送指令

                  MOVC A,@A+DPTR

                  本指令是將ROM中的數(shù)送入A中。本指令也被稱為查表指令,常用此指令來(lái)查一個(gè)已做好在ROM中的表格(類似C語(yǔ)言中的指針)

              說(shuō)明:

                  此條指令引出一個(gè)新的尋址方法:變址尋址。本指令是要在ROM的一個(gè)地址單元中找出數(shù)據(jù),顯然必須知道這個(gè)單元的地址,這個(gè)單元的地址是這樣確定的:在執(zhí)行本指令立腳點(diǎn)DPTR中有一個(gè)數(shù),A中有一個(gè)數(shù),執(zhí)行指令時(shí),將A和DPTR中的數(shù)加起為,就成為要查找的單元的地址。

                  1)查找到的結(jié)果被放在A中,因此,本條指令執(zhí)行前后,A中的值不一定相同。

                     例:有一個(gè)數(shù)在R0中,要求用查表的方法確定它的平方值(此數(shù)的取值范圍是0-5)

                      MOV DPTR,#TABLE

                      MOV A,R0

                      MOVC A,@A+DPTR

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

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

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

                    可以通過以下的例子再來(lái)看一看標(biāo)號(hà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。這個(gè)可以看懂了吧?

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

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

              堆棧操作

                PUSH direct

                POP #9; direct

                第一條指令稱之為推入,就是將direct中的內(nèi)容送入堆棧中,第二條指令稱之為彈出,就是將堆棧中的內(nèi)容送回到direct中。推入指令的執(zhí)行過程是,首先將SP中的值加1,然后把SP中的值當(dāng)作地址,將direct中的值送進(jìn)以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時(shí),是將SP+1,即變?yōu)?1H,然后將B中的值送入到61H單元中,即執(zhí)行完本條指令后,61H單元中的值變?yōu)?0。

                  POP指令的執(zhí)行是這樣的,首先將SP中的值作為地址,并將此地址中的數(shù)送到POP指令后面的那個(gè)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。


          上一頁(yè) 1 2 3 4 下一頁(yè)

          關(guān)鍵詞: MCS-51單片機(jī)匯編指

          評(píng)論


          相關(guān)推薦

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

          關(guān)閉
          看屁屁www成人影院,亚洲人妻成人图片,亚洲精品成人午夜在线,日韩在线 欧美成人 (function(){ var bp = document.createElement('script'); var curProtocol = window.location.protocol.split(':')[0]; if (curProtocol === 'https') { bp.src = 'https://zz.bdstatic.com/linksubmit/push.js'; } else { bp.src = 'http://push.zhanzhang.baidu.com/push.js'; } var s = document.getElementsByTagName("script")[0]; s.parentNode.insertBefore(bp, s); })();