<li id="8g3ty"><tbody id="8g3ty"><th id="8g3ty"></th></tbody></li>
    <label id="8g3ty"><samp id="8g3ty"></samp></label>
  • <span id="8g3ty"></span>

    1. <center id="8g3ty"><optgroup id="8g3ty"></optgroup></center>
    2. <bdo id="8g3ty"><meter id="8g3ty"><bdo id="8g3ty"></bdo></meter></bdo><center id="8g3ty"><optgroup id="8g3ty"></optgroup></center>
      <label id="8g3ty"><samp id="8g3ty"></samp></label>

    3. 電子開發網

      電子開發網電子設計 | 電子開發網Rss 2.0 會員中心 會員注冊
      搜索: 您現在的位置: 電子開發網 >> 電子開發 >> 單片機 >> 正文

      51單片機指令系統(6)

      作者:佚名    文章來源:網上收集    點擊數:    更新時間:2008-11-4
      第二十四課:算術運算類指令分析
      算術運算指令共有24條,算術運算主要是執行加、減、乘、除法四則運算。另外MCS-51指令系統中有相當一部分是進行加、減1操作,BCD碼的運算和調整,我們都歸類為運算指令。雖然MCS-51單片機的算術邏輯單元ALU僅能對8位無符號整數進行運算,但利用進位標志C,則可進行多字節無符號整數的運算。同時利用溢出標志,還可以對帶符號數進行補碼運算。需要指出的是,除加、減1指令外,這類指令大多數都會對PSW(程序狀態字)有影響。這在使用中應特別注意。

      [1]. 加法指令(4條)
      這4條指令的作用是把立即數,直接地址、工作寄存器及間接地址內容與累加器A的內容相加,運算結果存在A中。

      ADD  A,#data   ;(A)+#data→(A) 累加器A中的內容與立即數#data相加,結果存在A中
      ADD  A,data    ;(A)+(data)→(A) 累加器A中的內容與直接地址單元中的內容相加,結果存在A中
      ADD  A,Rn     ;(A)+(Rn)→(A) 累加器A中的內容與工作寄存器Rn中的內容相加,結果存在A中
      ADD  A,@Ri    ;(A)+((Ri))→(A) 累加器A中的內容與工作寄存器Ri所指向地址單元中的內容相加,結果存在A中

      這些指令所用到的源操作數都是累加器ACC,目的操作數則根據自已的需要來選擇。

      上述這四條指令的用途是:將A中的值與后面的值相加,最終結果存回到累加器A中。
      例:MOV  A,#30H
          ADD  A,#10H
      則執行完本條指令后,A中的值就是40H
      下面的題目請大家自行練習
          MOV  34H,#10H
          MOV  R0,#13H
          MOV  A,34H
          ADD  A,R0
          MOV  R1,#34H
          ADD  A,@R1

      練習題說明:
      MOV 34H,#10H
      這條指令的目的是將立即數10H送入34H這個存儲單元
      MOV R0,#13H
      這條指令的目的是將立即數13H送入R0這個寄存器
      MOV A,34H
      這條指令大家要特別注意了,這條指令的源操作數在哪里呢?它的源操作數是在34H這個存儲單元里,也就是34H是個存儲單元,而不是一個數
      這條指令用的是直接尋址,大前看前面的指令,第一條指令將10H這個立即數送入了34H這個存儲單元。那么,也就是34H中存儲著10H這么一個常數。
      執行MOV  A,34H單元后,累加器A中的值是多少呢?前面說了34H存儲單元中的值是10H,所以這時累加器的值就是10H。
      ADD A,R0
      這條指令其實就是把前面三條指令的數據求個總和。第二條指令MOV  R0,#13H執行完后。R0寄存器里的值是13H。第三條指令MOV A,34H執行完后,累加器的值是10H。
      這條指令的意思就是把R0寄存器中的值(13H)與累加器A中的值(10H)相加,其結果是(23H)送入累加器A。
      MOV R1,#34H
      這條指令是將常數34H送入寄存器R1,執行完這條指令后,R1寄存器中的值是34H
      ADD A,@R1
      這個時候求和,大家請注意了。這條指令是寄存器間接尋址方式。前面我們已知道,累加器中的值是23H,MOV  R1,#34H執行完后,R1寄存器的值是34H。大家注意,在間接尋址方式MOV  A,@Ri(Ri為R0或R1,在這條指令中用的是R1)中。R1內的值指的就不是一個常數了,而是一個直接地址。這條指令的意思就是把寄存器R1中存儲的34H存儲單元的內容(10H)與累加器中的內容(23H)相加,其結果為33H。

      根據前面我們用的MedWin仿真軟件大家進行模擬仿真,同時打開DATA窗口及寄存器窗口觀察程序執行時內部寄存器及數據區的變化情況。軟件使用如有不凝問,請到我們論壇提出。我們會盡力為大家解答。

      [2]. 帶進位加法指令(4條)
      這4條指令除與[1]功能相同外,在進行加法運算時還需考慮進位問題。

      ADDC    A,data    ;(A)+(data)+(C)→(A) 累加器A中的內容與直接地址單元的內容連同進位位相加,結果存在A中
      ADDC    A,#data   ;(A)+#data +(C)→(A) 累加器A中的內容與立即數連同進位位相加,結果存在A中
      ADDC    A,Rn      ;(A)+Rn+(C)→(A) 累加器A中的內容與工作寄存器Rn中的內容、連同進位位相加,結果存在A中
      ADDC    A,@Ri     ;(A)+((Ri))+(C)→(A) 累加器A中的內容與工作寄存器Ri指向地址單元中的內容、連同進位位相加,結果存在A中

      用途:將A中的值和其后面的值相加,并且加上進位位C中的值。
      說明:由于51單片機是一種8位機,所以只能做8位的數學運算,但8位的運算范圍只有0-255,這在實際工作中是不夠的,因此就要進行擴展,一般是將2個8位的數學運算合起來,成為一個16位的運算,這樣,可以表達的數的范圍就可以到達0-65535。如何合并呢?其實很簡單,讓我們看一個十進制數的例子吧:
      66+78
      這兩個數相加,我們根本不在意這個過程,但事實上我們是這樣做的:先做6+8(低位),然后再做6+7,這是高位。做了兩次加法,只是我們做的時候并沒有刻意分成兩次加法來做罷了,或者說我們并沒有意識到我們做了兩次加法。之所以要分成兩次來做,是因為這兩個數超過了一位數所能表達的范圍(0-9)。
      在做低位時產生了進位,我們做的時候是在適當的位置點一下,然后在做高位加法時將這一點加進去。那么計算機中做16位加法時同樣如此,先做低8位的,如果兩數相加后產生了進位,也要“點一下”做個標記,這個標記就職進位位C,在程序狀態字PSW中。在進行高位加法是將這個C加進去。
      例如:1067H+10A0H,先做67H+A0H=107H,而107H顯然超過了0FFH,因此,最終保存在A中的數是7,而1則到了PSW中的CY位了,換言之,CY就相當于100H。然后再做10H+10H+CY,結果是21H,所以最終的結果是2107H。

      [3]. 帶借位減法指令(4條)
      這組指令包含立即數、直接地址、間接地址及工作寄存器與累加器A連同借位位C內容相減,結果送回累加器A中。
      這里我們對借位位C的狀態作出說明,在進行減法運算中,CY=1表示有借位,CY=0則無借位。OV=1聲明帶符號數相減時,從一個正數減去一個負數結果為負數,或者從一個負數中減去一個正數結果為正數的錯誤情況。在進行減法運算前,如果不知道借位標志位C的狀態,則應先對CY進行清零操作。

      SUBB  A,data      ;(A)-(data) - (C)→(A) 累加器A中的內容與直接地址單元中的內容、連同借位位相減,結果存在A中
      SUBB  A,#data     ;(A)-#data -(C)→(A) 累加器A中的內容與立即數、連同借位位相減,結果存在A中
      SUBB  A,Rn       ;(A)-(Rn) -(C)→(A) 累加器A中的內容與工作寄存器中的內容、連同借位位相減,結果存在A中
      SUBB  A,@Ri      ;(A)-((Ri)) -(C)→(A) 累加器A中的內容與工作寄存器Ri指向的地址單元中的內容、連同借位位相減,結果存在A中

      [4]. 乘法指令(1條)
      這個指令的作用是把累加器A和寄存器B中的8位無符號數相乘,所得到的是16位乘積,這個結果低8位存在累加器A,而高8位存在寄存器B中。如果OV=1,說明乘積大于0FFFFH(65536),否則OV=0,但進位標志位CY總是等于0。

      MUL  AB       ;(A)×(B)→(A)和(B) 累加器A中的內容與寄存器B中的內容相乘,結果存在A、B中

      例:(A)=4EH,(B)=5DH,執行指令
          MUL  AB后,乘積是1C56H,所以在B中放的是1CH,而A中放的則是56H。

      [5].  除法指令(1條)
      這個指令的作用是把累加器A的8位無符號整數除以寄存器B中的8位無符號整數,所得到的商存在累加器A,而余數存在寄存器B中。除法運算總是使OV和進位標志位CY等于0。如果OV=1,表明寄存器B中的內容為00H,那么執行結果為不確定值,表示除法有溢出。

      DIV  AB       ;(A)÷(B)→(A)和(B) 累加器A中的內容除以寄存器B中的內容,所得到的商存在累加器A,而余數存在寄存器B中。


      例如:13/5,其商是2,余數是3。除了以后,商會放在A中,余數放在B中,CU和OV都是0。如果在做除法前B中的值是00H,也就是除數為0,那么OV=1。

      [6]. 加1指令(5條)
      這5條指令的的功能均為原寄存器的內容加1,結果送回原寄存器。上述提到,加1指令不會對任何標志有影響,如果原寄存器的內容為FFH,執行加1后,結果就會是00H。這組指令共有直接、寄存器、寄存器減間址等尋址方式:

      INC  A          ;(A)+1→(A) 累加器A中的內容加1,結果存在A中
      INC  data       ;(data)+1→(data) 直接地址單元中的內容加1,結果送回原地址單元中
      INC  @Ri       ;((Ri))+1→((Ri)) 寄存器的內容指向的地址單元中的內容加1,結果送回原地址單元中
      INC  Rn         ;(Rn)+1→(Rn)寄存器Rn的內容加1,結果送回原地址單元中
      INC  DPTR      ;(DPTR)+1→(DPTR)數據指針的內容加1,結果送回數據指針中

      用途很簡單,就是將后面目標中的值加1。
      例:(A)=12H,(R0)=33H,(21H)=32H,(34H)=22H,DPTR=1234H。執行下面的指令;
      INC  A   ;(A)=13H
      INC  R0  ;(R0)=34H
      INC  21H ;(21H)=33H
      INC  @R0 ;(34H)=23H
      INC  DPTR;(DPTR)=1235H
      這些指令執行后的結果都附在了指令的后面。
      說明:從結果上看,INC  A和ADD A,#1差不多,但INC  A是單字節,單周期指令,而ADD  A,#1則是雙字節雙周期指令,而且INC  A不會影響PSW位,如(A)=0FFH,INC  A后(A)=00H,而CY依然保持不變。如果是ADD A,#1,則(A)=00H,而CY一定是1。因此加1指令并不適合做加法運算,事實上它主要是用來做計數、地址增加等用途。另外,加法類指令都是以A為核心的,其中一個數必須放在A中,而運算結果也必須放在A中,而加1類指令的對象則廣泛得多,可以是寄存器、內存地址、間址尋址的地址等等。

      在INC  data這條指令中,如果直接地址是I/O,其功能是先讀入I/O鎖存器的內容,然后在CPU進行加1操作,再輸出到I/O上,這就是“讀—修改—寫”操作。

      [7].  減1指令(4條)
      這組指令的作用是把所指的寄存器內容減1,結果送回原寄存器,若原寄存器的內容為00H,減1后即為FFH,運算結果不影響任何標志位,這組指令共有直接、寄存器、寄存器間址等尋址方式,當直接地址是I/O口鎖存器時,“讀—修改—寫”操作與加1指令類似。

      DEC  A         ;(A)-1→(A)累加器A中的內容減1,結果送回累加器A中
      DEC  data      ;(data)-1→(data)直接地址單元中的內容減1,結果送回直接地址單元中
      DEC  @Ri      ;((Ri))-1→((Ri))寄存器Ri指向的地址單元中的內容減1,結果送回原地址單元中

      DEC  Rn      ;(Rn)-1→(Rn)寄存器Rn中的內容減1,結果送回寄存器Rn中

      [8]. 十進制調整指令(1條)
      在進行BCD碼運算時,這條指令總是跟在ADD或ADDC指令之后,其功能是將執行加法運算后存于累加器A中的結果進行調整和修正。

      DA      A

      綜合練習:
         MOV   A,#12H
         MOV   R0,#24H
         MOV   21H,#56H
         ADD   A,#12H
         MOV   DPTR,#1234H
         ADD   A,DPH
         ADD   A,R0
         CLR   C
         SUBB  A,DPL
         SUBB  A,#25H
         INC   A
         SETB  C
         ADDC  A,21H
         INC   R0
         SUBB  A,R0
         MOV   24H,#16H
         CLR   C
         ADD   A,@R0
      先寫出每步運行結果,然后將以上題目鍵入,并在軟件仿真中運行,觀察寄存器及有關單元的內容的變化。看結果是否與預想的結果相同?
      關于軟件仿真的具體使用方法,我們會專門安排一節課給大家學習。敬請期待!
      Tags:單片機,指令系統,數據傳輸方式,電子設計  
      責任編輯:admin
      請文明參與討論,禁止漫罵攻擊,不要惡意評論、違禁詞語。 昵稱:
      1分 2分 3分 4分 5分

      還可以輸入 200 個字
      [ 查看全部 ] 網友評論
      關于我們 - 聯系我們 - 廣告服務 - 友情鏈接 - 網站地圖 - 版權聲明 - 在線幫助 - 文章列表
      返回頂部
      刷新頁面
      下到頁底
      晶體管查詢
      主站蜘蛛池模板: 色综合久久久久无码专区| 国产综合视频在线观看一区| 色天使亚洲综合一区二区| 综合在线免费视频| 成人综合国产乱在线| 综合三区后入内射国产馆| 婷婷色香五月综合激激情| 狠狠色综合7777久夜色撩人| 婷婷亚洲综合一区二区| 天天爽天天狠久久久综合麻豆 | 伊人久久亚洲综合影院首页| 久久婷婷成人综合色综合| 国产成人久久综合二区| 久久久久久久综合色一本| 色综合天天综合网看在线影院| 狠狠色婷婷七月色综合| 色综合久久中文字幕| 99久久综合狠狠综合久久aⅴ| 色综合久久天天综合绕观看 | 色综合久久天天综合绕观看| 精品亚洲综合久久中文字幕| 久久婷婷成人综合色综合| 亚洲人成依人成综合网| av一本久道久久综合久久鬼色| 亚洲国产成+人+综合| 伊人色综合一区二区三区| 国产成人综合久久精品下载| 亚洲综合av一区二区三区不卡| 狠狠色丁香久久综合五月| 国产在线一区二区综合免费视频| 国产成人精品综合| 亚洲 自拍 另类小说综合图区| 国产成人综合久久精品| 国产色婷婷精品综合在线| 加勒比色综合久久久久久久久| 色噜噜狠狠狠狠色综合久| 狠狠色婷婷丁香综合久久韩国| 色综合网天天综合色中文男男| 色欲久久久天天天综合网精品| 狠狠色丁香久久综合婷婷| 久久婷婷香蕉热狠狠综合|