㈠ 定址方式
定址方式(或編址方式)指的是確定本條指令的數據地址及下一條要執行的指令地址的方法。
所需的操作數由指令的地址碼部分直接給出,就稱為立即數(直接數)定址方式。
特點:
取指時,操作碼和一個操作數同時被取出,減少了訪問存儲器次數,提高了指令的執行速度。但只適用於操作數固定的情況。
計算機的中央處理器一般設置有一定數量的通用寄存器,用以存放操作數,操作數的地址或中間結果。通用寄存器的數量一般在幾個至幾十個之間,比存儲單元少很多,因此地址碼短,節省存儲空間,提高指令的執行速度,而且從寄存器中存取數據比從存儲器中存取快的多。
是最直觀的一種方式,指令的地址碼部分給出操作數在存儲器中的地址,而該指令的定址方式由操作碼表示。
有時根據指令的地址碼所取出的既不是操作數,也不是下一條要執行的指令,而是操作數的地址或指令的地址,這種方式稱為間接定址(間址)(第一次讀出操作數地址,第二次讀出操作數)。大多數計算機只允許一次間址。
間接定址又可分為寄存器間接定址和存儲器間接定址兩種。
在計算機中設置一個專用的基址寄存器,或由指令指定一個通用寄存器為基址寄存器。操作數的地址由基址寄存器的內容和指令的地址碼A相加得到,地址碼A通常被稱為位移量(disp)。
操作數的地址由指令地址碼部分給出的地址碼A和指定的變址寄存器的內容通過加法器相加得到。這是幾乎所有計算機都採用的一種定址方式。
當計算機中還有基址寄存器時,也要加上基址寄存器內容。
把程序計數器PC的內容(即當前執行指令的地址)與指令的地址碼部分給出的位移量(Disp)之和作為操作數的地址或轉移地址。
相對定址主要用於轉移指令,執行本條指令後,將轉移到(PC)+ Disp。
特點:
轉移地址不固定。
位移量可正可負,通常用補碼表示。
㈡ 存儲器定址方式有哪些立即數定址和寄存器定址是嗎
立即定址,寄存器定址,直接定址,寄存器間接定址,位定址,基址加變址寄存器間接定址,相對定址,一共7種
㈢ 匯編語言中哪些定址方式訪問存儲器,哪些定址方式是訪問存儲單元
匯編一共有七種定址方式:
1,直接定址,如: mov ax,[100]
2,寄存器定址,如:mov ax,bx
3,立即數定址:如:mov ax,1000h
4,寄存器間接定址,如:mov ax,[bx]
5,寄存器相對定址,如:mov ax,,[bx+x],x為一個位元組長度或者一個字的長度
6,基址加變址定址,如:mov ax,[bx+si/di]
7,相對基址加變址定址,如:mov ax,[bx+si/di+x]
希望對你有幫助
㈣ S7-200PLC存儲器定址方式有哪幾種
S7-200PLC根據存儲器的編程元件,把數據存儲在不同的存儲單元,通過每個單元的地址 進行數據訪問,訪問數據的過程稱為「定址」,根據訪問數據存取的方式不同.可劃分為直接定址和間接定址。
1.直接定址
直接定址就是明確存儲器的區域、長度和位置,直接使用存儲器編程元件的名稱和地址進行數據交換,使用戶程序直接存取這些數據。直接定址包括位定址、位元組定址、字定址、雙字定址等方式。
(1)位定址方式
位(bit)定址方式用來表示「開關量或邏輯量」的工作過程。進行位定址時,要指定存儲器 編程元件的名稱、位元組地址和位地址,並把該位看成是一個獨立的元件。
(2)位元組、字、雙字定址方式
除了按位定址方式外,還可按數據存儲區域(I、Q、M、V、L、 S、SM等)的位元組、字和雙字的地址格式存取數據,進行位元組、字、雙字定址方式時,要指定存儲區域標識符、數據長度和起始地址。
2.間接定址
間接定址是使用指針的方式來訪問存儲器中的數據,而不是直接使用編程元件的地址編號 來訪問存儲器中的數據。
㈤ 總結及分析各種定址方式。
第二十二課:51單片機的定址方式
學習匯編程序設計,要先了解CPU的各種定址法,才能有效的掌握各個命令的用途,定址法是命令運算碼找操作數的方法。
指令的定址方式
MOV P1,#0FFH這條指令,第一個詞MOV是命令動詞,也就是決定做什麼事情的,MOV是MOVE少寫了一個E,所以就是「傳遞」,這就是指令,規定做什麼事情,數據傳遞必須要有一個「源」也就是你要送什麼數,必須要有一個「目的」,也就是你這個數要送到什麼地方去,顯然在上面那條指令中,要送的數(源)就是0FFH,而要送達的地方(目的地)就是P1這個寄存器。
定址方式:指定操作數所在單元的方法。注意:源操作數、目的操作數都有各自的定址方式。
掌握指令的7種定址方式的作用以及不同定址方式所查詢的存儲空間及范圍,對於常用的指令,能夠給出指令的定址方式。在我們學習的8051單片機中,有7種定址方法,下面我們將逐一進行分析。
立即定址所要找的操作數是一二進制數或十進制數,出現在指令中,用「#」作前綴MOV A,#20H在這種定址方式中,指令多是雙位元組的,一般第一個位元組是操作碼,第二個位元組是操作數。該操作數直接參與操作,所以又稱立即數,有「#」號表示。立即數就是存放在程序存儲器中的常數,換句話說就是操作數(立即數)是包含在指令位元組中的。例如:MOV A,#3AH這條指令的指令代碼為74H、3AH,是雙位元組指令,這條指令的功能是把立即數3AH送入累加器A中。MOV DPTR,#8200H在前面學單片機的專用寄存器時,我們已學過,DPTR是一個16位的寄存器,它由DPH及DPL兩個8位的寄存器組成。這條指令的意思就是把立即數的高8位(即82H)送入DPH寄存器,把立即數的低8位(即00H)送入DPL寄存器。這里也特別說明一下:在80C51單片機的指令系統中,僅有一條指令的操作數是16位的立即數,其功能是向地址指針DPTR傳送16位的地址,即把立即數的高8位送入DPH,低8位送入DPL。
直接定址指令中直接給出操作數的地址。MOV A,30HMOV 30H,DPH直接定址方式是指在指令中操作數直接以單元地址的形式給出,也就是在這種定址方式中,操作數項給出的是參加運算的操作數的地址,而不是操作數。例如:MOV A,30H 這條指令中操作數就在30H單元中,也就是30H是操作數的地址,並非操作數。在80C51單片機中,直接地址只能用來表示特殊功能寄存器、內部數據存儲器以及位地址空間,
具體的說就是:
1、內部數據存儲器RAM低128單元。在指令中是以直接單元地址形式給出。我們知道低128單元的地址是00H-7FH。在指令中直接以單元地址形式給出這句話的意思就是這0-127共128位的任何一位,例如0位是以00H這個單元地址形式給出、1位就是以01H單元地址給出、127位就是以7FH形式給出。
2、位定址區。20H-2FH地址單元。
3、特殊功能寄存器。專用寄存器除以單元地址形式給出外,還可以以寄存器符號形式給出。例如下面我們分析的一條指令 MOV IE,#85H 前面的學習我們已知道,中斷允許寄存器IE的地址是80H,那麼也就是這條指令可以以MOV IE,#85H 的形式表述,也可以MOV 80H,#85H的形式表述。 關於數據存儲器RAM的內部情況,請查看我們課程的第十二課。
直接定址是唯一能訪問特殊功能寄存器的定址方式!大家來分析下面幾條指令:
MOV 65H,A ;將A的內容送入內部RAM的65H單元地址中
MOV A,direct ;將直接地址單元的內容送入A中
MOV direct,direct;將直接地址單元的內容送直接地址單元
MOV IE,#85H ;將立即數85H送入中斷允許寄存器IE前面我們已學過,數據前面加了「#」的,表示後面的數是立即數(如#85H,就表示85H就是一個立即數),數據前面沒有加「#」號的,就表示後面的是一個地址地址(如,MOV 65H,A這條指令的65H就是一個單元地址)。
寄存器定址操作數存放在工作寄存器R0 ~ R7中,或寄存器B中。
MOV A,R2寄存器定址的定址范圍是:
1、4個工作寄存器組共有32個通用寄存器,但在指令中只能使用當前寄存器組(工作寄存器組的選擇在前面專用寄存器的學習中,我們已知道,是由程序狀態字PSW中的RS1和RS0來確定的),因此在使用前常需要通過對PSW中的RS1、RS0位的狀態設置,來進行對當前工作寄存器組的選擇。
2、部份專用寄存器。例如,累加器A、通用寄存器B、地址寄存器DPTR和進位位CY。
寄存器定址方式是指操作數在寄存器中,因此指定了寄存器名稱就能得到操作數。
例如:
MOV A,R0這條指令的意思是把寄存器R0的內容傳送到累加器A中,操作數就在R0中。
INC R3這條指令的意思是把寄存器R3中的內容加1
從前面的學習中我產應可以理解到,其實寄存器定址方式就是對由PSW程序狀態字確定的工作寄存器組的R0-R7進行讀/寫操作。寄存器間接定址指令中寄存器的內容作為操作數存放的地址,指令中間接定址寄存器前用「@」表示前綴。舉「兩個抽屜,兩把鑰匙」的例子。
MOV R0,#30H
MOV A,@R0
MOV A,#20H
MOV R1,#40H
MOV @R1,A
寄存間接定址方式是指寄存器中存放的是操作數的地址,即操作數是通過寄存器間接得到的,因此稱為寄存器間接定址。MCS-51單片機規定工作寄存器的R0、R1做為間接定址寄存器。用於定址內部或外部數據存儲器的256個單元。
為什麼會是256個單元呢?
我們知道,R0或者R1都是一個8位的寄存器,所以它的定址空間就是2的八次方=256。
例:MOV R0,#30H ;將值30H載入到R0中
MOV A,@R0 ;把內部RAM地址30H內的值放到累加器A中
MOVX A,@R0 ;把外部RAM地址30H內的值放到累加器A中
大家想想,如果用DPTR做為間址寄存器,那麼它的定址范圍是多少呢?DPTR是一個16位的寄存器,所以它的定址范圍就是2的十六次方=65536=64K。因用DPTR做為間址寄存器的定址空間是64K,所以訪問片外數據存儲器時,我們通常就用DPTR做為間址寄存器。
例:MOV DPTR,#1234H ;將DPTR值設為1234H(16位)
MOVX A,@DPTR ;將外部RAM或I/O地址1234H內的值放到累加器A中
在執行PUSH(壓棧)和POP(出棧)指令時,採用堆棧指針SP作寄存器間接定址。
例:PUSH 30H ;把內部RAM地址30H內的值放到堆棧區中堆棧區是由SP寄存器指定的,如果執行上面這條命令前,SP為60H,命令執行後會把內部RAM地址30H內的值放到RAM的61H內。
那麼做為寄存器間接定址用的寄存器主要有哪些呢?
我們前面提到的有四個,R0、R1、DPTR、SP寄存器
間接定址范圍總結:
1、內部RAM低128單元。對內部RAM低128單元的間接定址,應使用R0或R1作間址寄存器,其通用形式為@Ri(i=0或1)。
2、外部RAM 64KB。對外部RAM64KB的間接定址,應使用@DPTR作間址定址寄存器,其形式為:@DPTR。
例如MOVX A,@DPTR;其功能是把DPTR指定的外部RAM的單元的內容送入累加器A中。
外部RAM的低256單元是一個特殊的定址區,除可以用DPTR作間址寄存器定址外,還可以用R0或R1作間址寄存器定址。
例如MOVX A,@R0;這條指令的意思是,把R0指定的外部RAM單元的內容送入累加器A。
堆棧操作指令(PUSH和POP)也應算作是寄存器間接定址,即以堆棧指針SP作間址寄存器的間接定址方式。
寄存器間接定址方式不可以訪問特殊功能寄存器!寄存器間接定址也須以寄存器符號的形式表示,為了區別寄存器定址我寄存器間接定址的區別,在寄存器間接定址方式式中,寄存器的名稱前面加前綴標志「@」。
基址寄存器加變址寄存器的變址定址
操作數地址 = 變地址 + 基地址
基地址寄存器 DPTR 或 PC
變址寄存器 @A
該定址方式常用於訪問程序存儲器,查表。MOV A,@A + DPTR
這種定址方式以程序計數器PC或DPTR為基址寄存器,累加器A為變址寄存器,變址定址時,把兩者的內容相加,所得到的結果作為操作數的地址。這種方式常用於訪問程序存儲器ROM中的數據表格,即查表操作。
變址定址只能讀出程序內存入的值,而不能寫入,也就是說變址定址這種方式只能對程序存儲器進行定址,或者說它是專門針對程序存儲器的定址方式。
例:MOVC A,@A+DPTR這條指令的功能是把DPTR和A的內容相加,再把所得到的程序存儲器地址單元的內容送A
假若指令執行前A=54H,DPTR=3F21H,則這條指令變址定址形成的操作數地址就是54H+3F21H=3F75H。如果3F75H單元中的內容是7FH,則執行這條指令後,累加器A中的內容就是7FH。
變址定址的指令只有三條,分別如下:
JMP @A+DPTR
MOVC A,@A+DPTR
MOVC A,@A+PC
第一條指令JMP @A+DPTR這是一條無條件轉移指令,這條指令的意思就是DPTR加上累加器A的內容做為一個16位的地址,執行JMP這條指令是,程序就轉移到A+DPTR指定的地址去執行。
第二、三條指令MOVC A,@A+DPTR和MOVC A,@A+PC指令
這兩條指令的通常用於查表操作,功能完全一樣,但使用起來卻有一定的差別,現詳細說明如下。
我們知道,PC是程序指針,是十六位的。DPTR是一個16位的數據指針寄存器,按理,它們的定址范圍都應是64K。我們在學習特殊功能寄存器時已知道,程序計數器PC是始終跟蹤著程序的執行的。也就是說,PC的值是隨程序的執行情況自動改變的,我們不可以隨便的給PC賦值。而DPTR是一個數據指針,我們就可以給空上數據指針DPTR進行賦值。
我們再看指令MOVC A,@A+PC這條指令的意思是將PC的值與累加器A的值相加作為一個地址,而PC是固定的,累加器A是一個8位的寄存器,它的定址范圍是256個地址單元。
講到這里,大家應可明白,MOVC A,@A+PC這條指令的定址范圍其實就是只能在當前指令下256個地址單元。所在,這在我們實際應用中,可能就會有一個問題,如果我們需要查詢的數據表在256個地址單元之內,則可以用MOVC A,@A+PC這條指令進行查表操作,如果超過了256個單元,則不能用這條指令進行查表操作。剛才我們已說到,DPTR是一個數據指針,這個數據指針我們可以給它賦值操作的。通過賦值操作。我們可以使MOVC A,@A+DPTR這條指令的定址范圍達到64K。這就是這兩條指令在實際應用當中要注意的問題。
變址定址方式是MCS-51單片機所獨有的一種定址方式。
位定址
80C51單片機有位處理功能,可以對數據位進行操作,因此就有相應的位定址方式。所謂位定址,就是對內部RAM或可位定址的特殊功能寄存器SFR內的某個位,直接加以置位為1或復位為0。
位定址的范圍,也就是哪些部份可以進行位定址:
1、我們在學習51單片機的存儲器結構時,我們已知道在單片機的內部數據存儲器RAM的低128單元中有一個區域叫位定址區。它的單元地址是20H-2FH。共有16個單元,一個單元是8位,所以位定址區共有128位。這128位都單獨有一個位地址,其位地址的名字就是00H-7FH。
這里就有一個比較麻煩的問題需要大家理解清楚了。我們在前面的學習中00H、01H。7FH等等,所表示的都是一個位元組(或者叫單元地址),而在這里,這些數據都變成了位地址。我們在指令中,或者在程序中如何來區分它是一個單元地址還是一個位地址呢?這個問題,也就是我們現在正在研究的位定址的一個重要問題。其實,區分這些數據是位地址還是單元地址,我們都有相應的指令形式的。這個問題我們在後面的指令系統學習中再加以論述。
2、對專用寄存器位定址。這里要說明一下,不是所有的專用寄存器都可以位定址的。具體哪些專用寄存器可以哪些專用寄存器不可以,請大家回頭去看看我們前面關於專用寄存器的相關文章。一般來說,地址單元可以被8整除的專用寄存器,通常都可以進行位定址,當然並不是全部,大家在應用當中應引起注意。
相對定址
把指令中給定的地址偏移量與本指令所在單元地址(PC內容)相加得到真正有效的操作數所存放的地址。
舉「李同學20歲,張同學比李同學大3歲」的例子。
JC 60H ;設(PC) = 2000H,
則當C = 1時,
轉移的目的地址 = (PC)+ 2 + 60H
專用寄存器的位定址表示方法:
下面我們以程序狀態字PSW來進行說明
1、直接使用位地址表示:看上表,PSW的第五位地址是D5,所以可以表示為D5H MOV C,D5H
2、位名稱表示:表示該位的名稱,例如PSW的位5是F0,所以可以用F0表示 MOV C,F0
3、單元(位元組)地址加位表示:D0H單元位5,表示為DOH.5 MOV C,D0H.5
4、專用寄存器符號加位表示:例如PSW.5 MOV C,PSW.5這四種方法實現的功能都是相同的,只是表述的方式不同而已。
例題:
1. 說明下列指令中源操作數採用的定址方式。
MOV R5,R7 答案:寄存器定址方式
MOV A,55H 直接定址方式
MOV A,#55H 立即定址方式
JMP @A+DPTR 變址定址方式
MOV 30H,C 位定址方式
MOV A,@R0 間接定址方式
MOVX A,@R0 間接定址方式
改錯題
請判斷下列的MCS-51單片機指令的書寫格式是否有錯,若有,請說明錯誤原因。
MOV R0,@R3 答案: 間址寄存器不能使用R2~R7。
MOVC A,@R0+DPTR 變址定址方式中的間址寄存器不可使用R0,只可使用A。
ADD R0,R1 運算指令中目的操作數必須為累加器A,不可為R0。
MUL AR0 乘法指令中的乘數應在B寄存器中,即乘法指令只可使用AB寄存器組合。
上一頁: 第二十一課:匯編程序的基本結構 下 一頁: 第二十三課:數據傳送類指令分析
更多資料請來教師吧:http://www.jiaoshi8.com
㈥ 訪問程序存儲器中的常數數據,可以使用哪些定址方式
1立即數定址;2寄存器定址;3.主存定址。
直接在指令中給出操作數,不需要存儲單元,執行速度快,但是顯然數據也不能冗長,通用型性就差,一般用來指定一些要求不高的整形整數。操作數來源於寄存器,結果也寫回寄存器。顯然這個主要用到寄存器,這也是他的名字的由來。
指令特點
MCS-51的指令系統由111條指令組成。如果按位元組數分類,有49條單位元組指令,46條雙位元組指令和16條三位元組指令,以單位元組指令為主;如果按照指令執行時間分類,有64條單周期指令、45條雙周期指令和2條四周期指令,以單周期指令為主。存儲效率高、執行速度快,可以進行直接地址到直接地址的數據傳送,能把一個並行I/O口中的內容傳送到內部RAM單元中而不必經過累加器A或工作寄存器Rn。這樣可以大大提高傳送速度和緩解累加器A的瓶頸效應。
㈦ 匯編語言的種定址方式
所謂定址方式, 就是尋找操作數地址的方式, 在用匯編語言編程時, 數據的存放、傳送、 運算都要通過指令來完成。 編程者必須自始至終都要十分清楚操作數的位置, 以及如何將它們傳送到適當的寄存器去參與運算。每一種計算機都具有多種定址方式。定址方式的多少是反映指令系統優劣的主要指標之一。
在 MCS -51單片機指令系統中, 有以下 7種定址方式:
(1) 立即定址;
(2) 直接定址;
(3) 寄存器定址;
(4) 寄存器間接定址;
(5) 基址寄存器加變址寄存器間接定址;
(6) 相對定址;
(7) 位定址。
1. 立即定址
立即定址方式是指操作數包含在指令位元組中。 跟在指令操作碼後面的數就是參加運算的數, 該操作數稱為立即數。 立即數有一位元組和二位元組兩種可能, 例如指令:
MOV A, # 3AH
MOV DPTR, # 0DFFFH
上述兩條指令均為立即定址方式, 第一條指令的功能是將立即數 3AH送累加器A中, 第二條指令的功能是將立即數 0DFFFH送數據指針DPTR中(0DFH→DPH, 0FFH→DPL)。
2. 直接定址
在指令中直接給出操作數的地址, 這種定址方式就屬於直接定址方式。在這種方式中, 指令的操作數部分直接是操作數的地址。
在MCS -51 單片機指令系統中, 直接定址方式中可以訪問 3 種存儲器空間:
(1) 內部數據存儲器的低 128 個位元組單元(00H~7FH)。
(2) 特殊功能寄存器。 特殊功能寄存器只能用直接定址方式進行訪問。
(3) 位地址空間。
3. 寄存器定址
在該定址方式中, 參加操作的數存放在寄存器里。寄存器包括8個工作寄存器R0~R7, 累加器A, 寄存器B、數據指針DPTR和布爾處理器的位累加器Cy。
4. 寄存器間接定址
指令中給出間接定址寄存器,其內容為操作數的地址。定址內部RAM區的數據時,可使用寄存器R0、R1 (、SP)作為地址指針; 當訪問外部RAM時, 可使用R0、 R1及DPTR作為地址指針。寄存器間接定址符號為「@」
5. 基址寄存器加變址寄存器間接定址
這種定址方式用於訪問程序存儲器中的數據表格, 它以基址寄存器DPTR或PC的內容為基本地址, 加上變址寄存器A的內容作為操作數的地址, 例如: MOVC A, @A+DPTR
MOVC A, @ A+PC
JMP @A+DPTR;散轉指令
6. 相對定址
在MCS -51 指令系統中設有轉移指令, 分為直接轉移和相對轉移指令, 在相對轉移指令中採用相對定址方式。這種定址方式是以PC的內容為基本地址, 加上指令中給定的偏移量作為轉移地址。指令中給出的偏移量是一個 8 位帶符號的常數, 可正可負, 其范圍為-128~+127。
7. 位定址
該種定址方式中, 操作數是內部RAM單元中某一位的信息。