日韩欧美视频第二区,秋霞成人午夜鲁丝一区二区三区,美女日批视频在线观看,av在线不卡免费

電子開發(fā)網(wǎng)

電子開發(fā)網(wǎng)電子設計 | 電子開發(fā)網(wǎng)Rss 2.0 會員中心 會員注冊
搜索: 您現(xiàn)在的位置: 電子開發(fā)網(wǎng) >> 電子開發(fā) >> 單片機 >> 正文

51單片機指令系統(tǒng)(6)

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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

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


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

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

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

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

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

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

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

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

[8]. 十進制調整指令(1條)
在進行BCD碼運算時,這條指令總是跟在ADD或ADDC指令之后,其功能是將執(zhí)行加法運算后存于累加器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
先寫出每步運行結果,然后將以上題目鍵入,并在軟件仿真中運行,觀察寄存器及有關單元的內(nèi)容的變化。看結果是否與預想的結果相同?
關于軟件仿真的具體使用方法,我們會專門安排一節(jié)課給大家學習。敬請期待!
Tags:單片機,指令系統(tǒng),數(shù)據(jù)傳輸方式,電子設計  
責任編輯:admin
請文明參與討論,禁止漫罵攻擊,不要惡意評論、違禁詞語。 昵稱:
1分 2分 3分 4分 5分

還可以輸入 200 個字
[ 查看全部 ] 網(wǎng)友評論
最新推薦
關于我們 - 聯(lián)系我們 - 廣告服務 - 友情鏈接 - 網(wǎng)站地圖 - 版權聲明 - 在線幫助 - 文章列表
返回頂部
刷新頁面
下到頁底
晶體管查詢
主站蜘蛛池模板: 湖北省| 英吉沙县| 仁化县| 鲁山县| 雅江县| 永泰县| 华安县| 社旗县| 嵊州市| 淮阳县| 金寨县| 大荔县| 宜阳县| 玛沁县| 莆田市| 渝北区| 宁蒗| 金坛市| 广安市| 轮台县| 新余市| 会理县| 历史| 文水县| 泰和县| 宁明县| 鞍山市| 镇平县| 长汀县| 盐城市| 抚顺县| 酉阳| 习水县| 恩平市| 敖汉旗| 哈巴河县| 安顺市| 阿巴嘎旗| 彩票| 重庆市| 敖汉旗|