1. 程式人生 > >51微控制器的data,xdata,code區別詳解

51微控制器的data,xdata,code區別詳解

dATa: 固定指前面0x00-0x7f的128個RAM,可以用acc直接讀寫的,速度最快,生成的程式碼也最小。
idATa:固定指前面0x00-0xff的256個RAM,其中前128和dATa的128完全相同,只是因為訪問的方式不同。
idATa是用類似C中的指標方式訪問的。
彙編中的語句為:mox ACC,@Rx.(不重要的補充:c中idATa做指標式的訪問效果很好)

xdATa: 外部擴充套件RAM,一般指外部0x0000-0xffff空間,用DPTR訪問。

pdATa: 外部擴充套件RAM的低256個位元組,地址出現在A0-A7的上時讀寫,用movx ACC,@Rx讀寫。這個比較特殊,而且C51好象有對此BUG, 建議少用。但也有他的優點,具體用法屬於中級問題,這裡不提。

startup.a51 的作用,和彙編一樣,在C中定義的那些變數和陣列的初始化就在startup.a51中進行,如果你在定義全域性變數時帶有數值,如unsigned char dATa xxx="100";,那startup.a51中就會有相關的賦值。如果沒有=100,startup.a51就會把他清0。(startup.a51 ==變數的初始化)。 這些初始化完畢後,還會設定SP指標。對非變數區域, 如堆疊區,將不會有賦值或清零動作。

有人喜歡改 startup.a51,為了滿足自己一些想當然的愛好,這是不必要的,有可能錯誤的。比如掉電保護的時候想儲存一些變數, 但改 startup.a51來實現是很笨的方法,實際只要利用非變數區域的特性,定義一個指標變數指向堆疊低部:0xff處就可實現。, 為什麼還要去改? 可以這麼說:任何時候都可以不需要改startup.a51,如果你明白它的特性。


bit
是在內部資料儲存空間中 20H .. 2FH 區域中一個位的地址,這在DATA的20H以後以位元組形式出現,可互相參照。另外加上 8051 可定址 的SFR,但剛剛試過,只是00H--7FH起作用,也就是說當資料有變化時顏色變紅,以後的從80H到--FFH就不是位定址區了,是位定址的特殊寄存 器,如涉及到了可位定址的那11個當然會有反應。

復位後,程式計數器PC的內容為0000H,內部RAM各單元的值不確定。
各功能暫存器的復位值如下:
堆疊指標SP的復位值為07H,累加器ACC、暫存器B的復位值為00H,資料指標DPTR的復位值為0000H,而p0、p1、p2、p3四個口的復位值為0FFH。其他SFR如PSW、TCON、TMOD、TL0、TH0、TL1、TH1的復位值也為00H。

wave中是低128位元組和高128位元組(0-7FH),低128位元組是片內RAM區,高128位元組(80-FFH)是SFR(特殊功能暫存器)bit則是位於低128位元組的20H .. 2FH 區域,即data的20H .. 2FH 區域

code 是在 0000H .. 0FFFFH 之間的一個程式碼地址。

我用
ORG     5000H
TAB:    DB      22H,3BH,43H,66H,5H,6DH,88H後,
CODE從5000H開始以後變成DB各位


data
是 在 0 到 127 之間的一個數據儲存器地址,或者加 128 .. 255 範圍內的一個特殊功能暫存器(SFR)地址。兩者訪問的方式不同。實際上由於PSW的復位設定PSW.3=RS0和PSW.4=RS1皆為0,所以通用工 作暫存器區就是第0區,所以data的00--07H部分是與 REG欄中的R0--R7對應的。以後的則僅代表低128位元組的內部RAM。
idata
是 0 to 255 範圍內的一個 idata 儲存器地址
idata與data重合低128位元組,有的地方只有DATA表示256位元組的片內RAM,
xdata 是 0- 65535 範圍內的一個 xdata 儲存器地址。

指標型別和儲存區的關係詳解
一、儲存型別與儲存區關係
data     --->     可定址片內ram
bdata     --->    可位定址的片內ram
idata     --->    可定址片內ram,允許訪問全部內部ram
pdata     --->   分頁定址片外ram (MOVX @R0) (256 BYTE/頁)
xdata     --->   可定址片外ram (64k 地址範圍FFFFH)
code     --->    程式儲存區 (64k 地址範圍),對應MOVC @DPTR

二、指標型別和儲存區的關係

對變數進行宣告時可以指定變數的儲存型別如:
uchar data x和data uchar x相等價都是在內ram區分配一個位元組的變數。

同樣對於指標變數的宣告,因涉及到指標變數本身的儲存位置和指標所指向的儲存區位置不同而進行相應的儲存區型別關鍵字的
使用如:

uchar xdata * data pstr

是指在內ram區分配一個指標變數("*"號後的data關鍵字的作用),而且這個指標本身指向xdata區("*"前xdata關鍵字的作用),
可能初學C51時有點不好懂也不好記。沒關係,我們馬上就可以看到對應“*”前後不同的關鍵字的使用在編譯時出現什麼情況。

......
uchar xdata tmp[10];     //在外ram區開闢10個位元組的記憶體空間,地址是外ram的0x0000-0x0009
......

第1種情況:

uchar data * data pstr;
pstr="tmp";

首先要提醒大家這樣的程式碼是有bug的, 他不能通過這種方式正確的訪問到tmp空間。 為什麼?我們把編譯後看到下面的彙編
程式碼:

MOV 0x08,#tmp(0x00)         ;0x08是指標pstr的儲存地址

看到了嗎!本來訪問外ram需要2 byte來定址64k空間,但因為使用data關鍵字(在"*"號前的那個),所以按KeilC編譯環境來說
就把他編譯成指向內ram的指標變量了,這也是初學C51的朋友們不理解各個儲存型別的關鍵字定義而造成的bug。特別是當工程中的
預設的儲存區類為large時,又把tmp[10] 宣告為uchar tmp[10] 時,這樣的bug是很隱祕的不容易被發現。

第2種情況:

uchar xdata * data pstr;
pstr = tmp;

這種情況是沒問題的,這樣的使用方法是指在內ram分配一個指標變數("*"號後的data關鍵字的作用),而且這個指標本身指向
xdata區("*"前xdata關鍵字的作用)。編譯後的彙編程式碼如下。

MOV 0x08,#tmp(0x00)         ;0x08和0x09是在內ram區分配的pstr指標變數地址空間
MOV 0x09,#tmp(0x00)

這種情況應該是在這裡所有介紹各種情況中效率最高的訪問外ram的方法了,請大家記住他。

第3種情況:

uchar xdata * xdata pstr;
pstr="tmp";

這中情況也是對的,但效率不如第2種情況。編譯後的彙編程式碼如下。

MOV DPTR, #0x000A         ;0x000A,0x000B是在外ram區分配的pstr指標變數地址空間
MOV A, #tmp(0x00)
MOV @DPTR, A
INC DPTR
MOV A, #tmp(0x00)
MOVX @DPTR, A

這種方式一般用在內ram資源相對緊張而且對效率要求不高的專案中。

第4種情況:

uchar data * xdata pstr;
pstr="tmp";

如果詳細看了第1種情況的讀者發現這種寫法和第1種很相似,是的,同第1 種情況一樣這樣也是有bug的,但是這次是把pstr分
配到了外ram區了。編譯後的彙編程式碼如下。

MOV DPTR, #0x000A         ;0x000A是在外ram區分配的pstr指標變數的地址空間
MOV A, #tmp(0x00)
MOVX @DPTR, A

第5種情況:

uchar * data pstr;
pstr="tmp";

大家注意到"*"前的關鍵字宣告沒有了,是的這樣會發生什麼事呢?下面這麼寫呢!對了用齊豫的一首老歌名來說就是 “請跟我
來”,請跟我來看看編譯後的彙編程式碼,有人問這不是在講C51嗎? 為什麼還要給我們看彙編程式碼。C51要想用好就要儘可能提升C51
編譯後的效率,看看編譯後的彙編會幫助大家儘快成為生產高效C51程式碼的高手的。還是看程式碼吧!

MOV 0x08, #0X01             ;0x08-0x0A是在內ram區分配的pstr指標變數的地址空間
MOV 0x09, #tmp(0x00)
MOV 0x0A, #tmp(0x00)

注意:這是新介紹給大家的,大家會疑問為什麼在前面的幾種情況的pstr指標變數都用2 byte空間而到這裡就用3 byte空間了
呢?這是KeilC的一個系統內部處理,在KeilC中一個指標變數最多佔用 3 byte空間,對於沒有宣告指標指向儲存空間型別的指標,
系統編譯程式碼時都強制載入一個位元組的指標型別分辯值。具體的對應關係可以參考KeilC的help中C51 User's Guide。

第6種情況:

uchar * pstr;
pstr="tmp";

這是最直接最簡單的指標變數宣告,但他的效率也最低。還是那句話,大家一起說好嗎!編譯後的彙編程式碼如下。

MOV DPTR, #0x000A         ;0x000A-0x000C是在外ram區分配的pstr指標變數地址空間
MOV A, #0x01
MOV @DPTR, A
INC DPTR
MOV DPTR, #0x000A
MOV A, #tmp(0x00)
MOV @DPTR, A
INC DPTR
MOV A, #tmp(0x00)
MOVX @DPTR, A

這種情況很類似第5種和第3種情況的組合,既把pstr分配在外ram空間了又增加了指標型別的分辨值。 

相關推薦

51微控制器data,idata,xdata,pdata的區別

在51系列微控制器中data,idata,xdata,pdata的區別: data:固定指前面0x00-0x7F的128byte的RAM,可以用ACC直接讀寫的,速度最快,生成的程式碼也最小。 idata:固定指前面0x00-0xFF的256byte的RAM,其中前12

51微控制器dataxdatacode區別

dATa: 固定指前面0x00-0x7f的128個RAM,可以用acc直接讀寫的,速度最快,生成的程式碼也最小。 idATa:固定指前面0x00-0xff的256個RAM,其中前128和dATa的128完全相同,只是因為訪問的方式不同。 idATa是用類似C中的指標方式訪問的。 彙編中的語句為:mox ACC

ArrayListVector和LinkedList區別

一、ArrayList ArrayList是一個可以處理變長陣列的型別,這裡不侷限於“數”組,ArrayList是一個泛型類,可以存放任意型別的物件。顧名思義,ArrayList是一個數組列表,因此其內部是使用一個數組來存放物件的,因為Object是一切型別的父類,因而ArrayList內部是有一個Obje

51微控制器dataxdatacode區別

dATa: 固定指前面0x00-0x7f的128個RAM,可以用acc直接讀寫的,速度最快,生成的程式碼也最小。 idATa:固定指前面0x00-0xff的256個RAM,其中前128和dATa的128完全相同,只是因為訪問的方式不同。 idATa是用類似C中的指標方式訪問的。 彙編中的語句為:mox ACC

51系列中data,idata,xdata,pdata的區別

         從資料儲存型別來說,8051系列有片內、片外程式儲存器,片內、片外資料儲存器,片內程式儲存器還分直接定址區和間接定址型別,分別對應code、data、xdata、idata以及根據51系列特點而設定的p

51微控制器的idata,xdata,pdata,data

轉載:https://www.cnblogs.com/jikexianfeng/p/5870357.html data: 固定指前面0x00-0x7f的128個RAM,可以用acc直接讀寫的,速度最快,生成的程式碼也最小。 bit :是指0x20-0x2f的可位定址區 ida

51微控制器 同時擴充套件ROMRAM的具體實現及kiel的具體設定

51MCU內部有RAM,ROM,不同於8031。儘管如今的增強行51MCU的內部RAM,ROM可能已經很大的空間。但就技術而言,擴充套件RAM,ROM還是需要學會的。         對於不同的設計方案需求,擴充套件可能基於以下任何一種設計:         A,只擴充套件

51微控制器外擴RAMROM操作。

      這是51微控制器內建的功能,可以讓我們少寫很多時序,讓程式碼變的整潔好看。      這裡先拓展點小知識:RAM,ROM的區別,地址資料匯流排,控制匯流排。                1.RAM是一種掉電會丟失資料的可讀可寫的儲存器。//其實題目上寫的是外擴r

關於keil單片機編程中的data,idata,xdata,pdata,code數據類型

賦值語句 很多 全局 一個 速度 根據 ans 告訴 常數 從數據存儲類型來說,8051系列有片內、片外程序存儲器,片內、片外數據存儲器,片內程序存儲器還分直接尋址區和間接尋址類型,分別對應code、data、xdata、idata以及根據51系列特點而設定的pdata類型

C51 keil中data,idata,xdata,pdata,code

從資料儲存型別來說,8051系列有片內、片外程式儲存器,片內、片外資料儲存器,片內程式儲存器還分直接定址區和間接定址型別,分別對應code、data、xdata、idata以及根據51系列特點而設定的pdata型別,使用不同的儲存器,將使程式執行效率不同,在編寫C51程式時,

SQL內連結外連線交叉連線聯合連線區別

一、準備工作: 建立資料表並填寫資訊 class表: student表: 二、詳解 1、內連結 INNER JOIN 用於取得兩個表中存在連線匹配關係的記錄(例如:某一列相等)。通常配合比較運算子(=或<>)一起使用。其中

background-size100%content和cover的區別

background-size中,100%和cover都是用於將圖片擴大或者縮放來適應整個容器。 1、引數:     background-size:contain; // 縮小圖片來適應元素的尺寸(保持畫素的長寬比);     background-size :cover

VMWARE虛擬機器三種網路模式(BRIDGEDNATHOST-ONLY)區別

原文:http://hao.jser.com/archive/7954/ VMware三種網路模式根本區別 提到VMware大家就想起了虛擬機器技術,虛擬機器技術在最近的幾年中得到了廣泛的發展,一些大型網路服務商都開始採用虛擬機器技術,不僅節省了投資成本,更節約了能源的消耗

Linux核心中selectpollepoll的區別

隨著2.6核心對epoll的完全支援,網路上很多的文章和示例程式碼都提供了這樣一個資訊:使用epoll代替傳統的poll能給網路服務應用帶來效能上的提升。但大多文章裡關於效能提升的原因解釋的較少,這裡我將試分析一下核心(2.6.21.1)程式碼中poll與epo

程序和執行緒定義概念區別

程序的定義及基本概念: 狹義定義:程序是正在執行的程式的例項(an instance of a computer program that is being executed)。 組成 程序是一個實體。每一個程序都有它自己的地址空間,一般情況下,包括文字區域(tex

c語言—棧區堆區全局區文字常量區程序代碼區

註意 進制 但是 ack int 運行時 內存區域 否則 數組 轉:http://www.cnblogs.com/xiaowenhui/p/4669684.html 一、預備知識—程序的內存分配 一個由C/C++編譯的程序占用的內存分為以下幾個部分1、棧區(stack)—

MVCMVP 和 MVVM 的

name one control ember 模式 hash 改名 主動性 主動 一、MVC MVC模式的意思是,軟件可以分成三個部分。 視圖(View):用戶界面。 控制器(Controller):業務邏輯 模型(Model):數據保存 各部分之間的通信方式如下

web服務處理過程各種I/O模型

web服務處理過程 各種i/o模型詳解 一, 進程,線程?進程是具有一定獨立功能的,在計算機中已經運行的程序的實體。在linux2.4以前,進程是基本運作的單位,在只是線程的系統中,線程才是最基本的運作單位,而進程只是線程的容器,程序本身只是指令,數據及其組織形式的描述,進程才是程序的真正運行實例。若

nagios 服務端與客戶端監控安裝與詳細配置各配置文件

this sql 引入 apache2 cpu load fine 宕機 pri require nagios 安裝與部署—————— 1、安裝前準備(1)創建nagios用戶和用戶組 [root@localhost ~]#groupadd nagios

Linux route命令和使用以及網卡命令

linux 路由 網卡一 路由的基礎知識:1)路由概念路由: 跨越從源主機到目標主機的一個互聯網絡來轉發數據包的過程路由器:能夠將數據包轉發到正確的目的地,並在轉發過程中選擇最佳路徑的設備路由表:在路由器中維護的路由條目,路由器根據路由表做路徑選擇直連路由:當在路由器上配置了接口的IP地址,並且接口狀態為