您的位置 首页 报告

51单片机的data,xdata,code差异详解

dATa:固定指前面0x00-0x7f的128个RAM,可以用acc直接读写的,速度最快,生成的代码也最小。idATa:固定指前面0x00-0xff的256个RAM,其中前128

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 之间的一个代码地址。

我用
ORG5000H
TAB:DB22H,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 Users 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空间了又增加了指针类型的分辩值。

声明:本文内容来自网络转载或用户投稿,文章版权归原作者和原出处所有。文中观点,不代表本站立场。若有侵权请联系本站删除(kf@86ic.com)https://www.86ic.net/ceping/baogao/255895.html

为您推荐

联系我们

联系我们

在线咨询: QQ交谈

邮箱: kf@86ic.com

关注微信
微信扫一扫关注我们

微信扫一扫关注我们

返回顶部