data-----指单片机内部自带RAM空间 xdata----指单片机外扩RAM空间 pdata----指单片机外扩RAM空间中的页面空间0x00~0xff(256字节/页),页地址由P2口决定。 bit--------指RAM中位寻址空间0x20~0x7f地址单元。 code-----指内部ROM或外扩FLASH空间。 转自:http://hi.baidu.com/haoyun81/blog/item/e9ded795f339294dd0135e09.html 在51系列中data,idata,xdata,pdata的区别: 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读写。 bdata如何使用它呢? char bdata MODE; 转自:http://blog.sina.com.cn/s/blog_4daf4df90100i5ej.html 再加上一点: 在80C51单片机的内部数据存储器中,20H~2FH为位操作区域,其中没位都有自己的位地址,可以对没一位进行位操作。位的地址空间为00H~07FH,共16*8=128位。20H的最低位为00H,2FH的最高位为7FH。对于字节地址能被8整除的特殊功能寄存器的没一位,也具有可寻址的位地址,其位地制从80H开始。特殊寄存器的地址和它的位的最低位位地址的数字相同,比如P0口的地制是80H,那么P0口的最低位位地制也是80H。这里要把地址和位地址分清楚,前一个是P0口的地址,它有8位,每位有位地址,最低位的位地址是80H,次之是81H,他们在物理结构上是分开的。 在C语言中我们应该这么来定义它:
bit a,c,d; /*定义几个位变量*/
uchar bdata put_1; /*在位寻址区域定义一个变量,而他的8位再分别定义一个标号*/ sbit buzzer=put_1^0; sbit led1=put_1^1; sbit led2=put_1^2; sbit led3=put_1^3; sbit led4=put_1^4; sbit run=put_1^5; sbit up=put_1^6; sbit down=put_1^7;
sbit led=P1^1; /*定义P1口的1口为led*/ 在编程中直接使用标号,可以给编程带来方便。 转自:http://hi.baidu.com/pingyi168/blog/item/6af0e51f70e16161f724e4c5.html 普通51系列单片机存储空间资源分配情况
单片机学习网http://www.51hei.com给大家整理出了上下这两个表格,方便大家查询。有问题可在评论或者论坛中提出。
单片机中关键字data,idata,xdata,pdata的区别data: 转自:http://blog.sina.com.cn/s/blog_554b1f1b0100baz0.html 下面的一张图可以很好的展示51单片机rom和ram的分配情况(2010.10.22更新) 一些新型的8051使用地址扩展寄存器对传统8051的代码和/或XDATA空间作了扩展。下图所示是为扩展型8051器件编程所用的存储器类型。当我们使用LX51连接/定位器来实现存储器换页(memory banking)时,这些存储器类型可用于传统的8051器件。除了大家知道的BL51连接/定位器的代码换页外,LX51连接/定位器也支持标准8051器件的XDATA和代码区域的数据换页。
注意 如果我们使用Dallas 390的连续模式,CODE的地址空间可以为C:0000 -C:0xFFFFFF。
扩展型8051的存储器布局 扩展型8051的存储器布局,如下图所示,把变量地址空间扩展为最大16MB。
在一些扩展型8051版本中,使用DPX特殊功能寄存器把DPTR寄存器扩展为一个24位寄存器。例如,Dallas 390提供了一种这种寻址被使能的新的操作模式。使用LX51中的存储器换页,我们甚至可以在传统8051器件中使用HCONST和HDATA存储器类型。 转自:http://blog.21ic.com/more.asp?name=Gonghighloam&id=21237 |