有一阵子自己十分困惑指针在C51中如何应用,今天在网上看到一篇文章,感觉挺不错的,转了过来,希望对有困惑的同学有些作用:
一般指针 一般指针的声明和使用均与标准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 char a_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 char a_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 //推荐
|