C51 指针问题
时间:11-09
来源:互联网
点击:
一般指针
一般指针的声明和使用均与标准C相同,不过同时还可以说明指针的存储类型,例如:
long * state;为一个指向long型整数的指针,而state本身则依存储模式存放。
char * xdata ptr;ptr为一个指向char数据的指针,而ptr本身放于外部RAM区,以上的long,char等指针指向的数据可存放于任何存储器中。
一般指针本身用3个字节存放,分别为存储器类型,高位偏移,低位偏移量。2.存储器指针
基于存储器的指针说明时即指定了存贮类型,例如:
char data * str;str指向data区中char型数据
int xdata * pow; pow指向外部RAM的int型整数。
这种指针存放时,只需一个字节或2个字节就够了,因为只需存放偏移量。
/*.........................................................................................
char * xdata ptr;//ptr本身放在Xdata(XRAM)区
char xdata * ptr;//ptr指向的数据放在Xdata(XRAM)区
........................................................................................*/
char xdata * px
char xdata * data px
data char xdata * px
这3者有什么不同??
char xdata * px
px本身存在于自动分配的空间,一般位于data中,指向的内容位于xdata
char xdata * data px
px本身存在于data空间,指向的内容位于xdata
data char xdata * px =char xdata *data px
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,建议少用。但也有他的优点,具体用法属于中级问题,这里不提。
xdata unsigned char *p; 和 unsigned char* xdata p; 完全一样。
因为C写法中允许“最前面的存储类型修饰符修饰最后面的对象。
(1) unsigned char * xdata p
表明指针本身位于Xdata,至于指向什么类型的地址,自由变换.
例如
unsigned chara_data;
unsigned char xdata b_xdata;
当p = &a_data;*p等于a_data;它表示p指向的地址自动转换成data地址
当p = &b_xata;*p等于b_data;它表示p指向的地址自动转换成xdata地址
(2)unsigned char xdata * p//注意:这种用法不推荐
表示指针指向的地址是xdata
unsigned chara_data;
unsigned char xdata b_xdata;
当p = &a_data;*p不等于a_data;因为尽管相对地址相同,但a_data的地址在data空间中,而p指向的地址是xdata空间。(KEIL也会提示空间匹配错误)
当p = &b_xata;*p等于b_data;因为b_data本身就放在xdata,而p指向的地址是xdata。所以没有问题。
所以在定义指针的时候,如果不确定传入的参数的空间范围是哪里,最好不要限定指针指向的地址。例如直接用unsigned char *p。它会根据不同参数的空间,自动寻找相应的地址!
unsigned char *p //推荐
一般指针的声明和使用均与标准C相同,不过同时还可以说明指针的存储类型,例如:
long * state;为一个指向long型整数的指针,而state本身则依存储模式存放。
char * xdata ptr;ptr为一个指向char数据的指针,而ptr本身放于外部RAM区,以上的long,char等指针指向的数据可存放于任何存储器中。
一般指针本身用3个字节存放,分别为存储器类型,高位偏移,低位偏移量。2.存储器指针
基于存储器的指针说明时即指定了存贮类型,例如:
char data * str;str指向data区中char型数据
int xdata * pow; pow指向外部RAM的int型整数。
这种指针存放时,只需一个字节或2个字节就够了,因为只需存放偏移量。
/*.........................................................................................
char * xdata ptr;//ptr本身放在Xdata(XRAM)区
char xdata * ptr;//ptr指向的数据放在Xdata(XRAM)区
........................................................................................*/
char xdata * px
char xdata * data px
data char xdata * px
这3者有什么不同??
char xdata * px
px本身存在于自动分配的空间,一般位于data中,指向的内容位于xdata
char xdata * data px
px本身存在于data空间,指向的内容位于xdata
data char xdata * px =char xdata *data px
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,建议少用。但也有他的优点,具体用法属于中级问题,这里不提。
xdata unsigned char *p; 和 unsigned char* xdata p; 完全一样。
因为C写法中允许“最前面的存储类型修饰符修饰最后面的对象。
(1) unsigned char * xdata p
表明指针本身位于Xdata,至于指向什么类型的地址,自由变换.
例如
unsigned chara_data;
unsigned char xdata b_xdata;
当p = &a_data;*p等于a_data;它表示p指向的地址自动转换成data地址
当p = &b_xata;*p等于b_data;它表示p指向的地址自动转换成xdata地址
(2)unsigned char xdata * p//注意:这种用法不推荐
表示指针指向的地址是xdata
unsigned chara_data;
unsigned char xdata b_xdata;
当p = &a_data;*p不等于a_data;因为尽管相对地址相同,但a_data的地址在data空间中,而p指向的地址是xdata空间。(KEIL也会提示空间匹配错误)
当p = &b_xata;*p等于b_data;因为b_data本身就放在xdata,而p指向的地址是xdata。所以没有问题。
所以在定义指针的时候,如果不确定传入的参数的空间范围是哪里,最好不要限定指针指向的地址。例如直接用unsigned char *p。它会根据不同参数的空间,自动寻找相应的地址!
unsigned char *p //推荐
C51指针问 相关文章:
- Windows CE 进程、线程和内存管理(11-09)
- RedHatLinux新手入门教程(5)(11-12)
- uClinux介绍(11-09)
- openwebmailV1.60安装教学(11-12)
- Linux嵌入式系统开发平台选型探讨(11-09)
- Windows CE 进程、线程和内存管理(二)(11-09)