C51如何使用指针变量剖析

上传人:re****.1 文档编号:492021128 上传时间:2023-10-27 格式:DOCX 页数:5 大小:68.35KB
返回 下载 相关 举报
C51如何使用指针变量剖析_第1页
第1页 / 共5页
C51如何使用指针变量剖析_第2页
第2页 / 共5页
C51如何使用指针变量剖析_第3页
第3页 / 共5页
C51如何使用指针变量剖析_第4页
第4页 / 共5页
C51如何使用指针变量剖析_第5页
第5页 / 共5页
亲,该文档总共5页,全部预览完了,如果喜欢就下载吧!
资源描述

《C51如何使用指针变量剖析》由会员分享,可在线阅读,更多相关《C51如何使用指针变量剖析(5页珍藏版)》请在金锄头文库上搜索。

1、MOVX就是用来读写外部 RAM的MOVC读写外部ROM可通过检测RI来判断RXD是否有信息C语言参考资料:指针类型和存储区的关系详解一、存储类型与存储区关系data -可寻址片内rambdata -可位寻址的片内ramidata -可寻址片内ram ,允许访问全部内部rampdata - 分页寻址片外 ram (MOVX R0 (256 BYTE/ 页xdata -可寻址片外ram (64k地址范围code -程序存储区(64k地址范围,对应MOVC DPTR二、指针类型和存储区的关系对变量进行声明时可以指定变量的存储类型如:uchar data x和data uchar x相等价都是在内r

2、am区分配一个字节的变量。同样对于指针变量的声明,因涉及到指针变量本身的存储位置和指针所指向的存储区位置不同而进行相应的存储区类型关键字的使用如:uchar xdata * data pstr是指在内ram区分配一个指针变量(*号后的data关键字的作用,而且这个指针本身指向xdata区(*前xdata关键字的作用,可能初学C51时有点不好懂也不好记。没关系,我们马上就可以看到对应“情后不同的关键字的使用在编译时出现什么情况。uchar xdata tmp10; 在外ram区开辟10个字节的内存空间,地址是外 ram的 0x0000 0x0009第1种情况:uchar data * data

3、pstr;pstr=tmp;首先要提醒大家这样的代码是有 bug的,他不能通过这种方式正确的访问到tmp空 问。为什么?我们把编译后看到下面的汇编代码:MOV 0x08,#tmp(0x00 ;0x08 是指针 pstr 的存储地址看到了吗!本来访问外ram需要2 byte来寻址64k空间,但因为使用data关键字(在*”号前的那个,所以按KeilC编译环境来说就把他编译成指向内ram的指针变量了,这也是初学 C51的朋友们不理解各个存储类型的关键字定义而造成的bug。特别是当工程中的默认的存储区类为large时,又把tmp10声明为uchar tmp10时,这样的bug 是很隐秘的不容易被发现

4、。第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;这中情况也是对的,但效率不如第

5、 2种情况。编译后的汇编代码如下。MOV DPTR, #0x000A ;0x000A,0x000B 是在外ram区分配的pstr指针变量地址空 问MOV A, #tmp(0x00MOV DPTR, AINC DPTRMOV A, #tmp(0x00MOVX DPTR, A这种方式一般用在内ram资源相对紧张而且对效率要求不高的项目中。第4种情况:uchar data * xdata pstr;pstr=tmp;如果详细看了第1种情况的读者发现这种写法和第1种很相似,是的,同第1种 情况一样这样也是有bug的,但是这次是把pstr分配到了外ram区了。编译后的汇编代码如下。MOV DPTR, #

6、0x000A ;0x000A 是在外ram区分配的pstr指针变量的地址空间MOV A, #tmp(0x00MOVX DPTR, A第5种情况:uchar * data pstr;pstr=tmp;大家注意到*前的关键字声明没有了,是的这样会发生什么事呢?下面这么写呢!对了用齐豫的一首老歌名来说就是请跟我来”,请跟我来看看编译后的汇编代码,有人问这不是在讲 C51吗?为什么还要给 我们看汇编代码。C51要想用好就要尽可能提升C51编译后的效率,看看编译后的汇编会帮助大家尽快成为生产高效C51代码的高手的。还是看代码吧!MOV 0x08, #0X01 ;0x08 0x0A是在内ram区分配的ps

7、tr指针变量的地址空间MOV 0x09, #tmp(0x00MOV 0x0A, #tmp(0x00注意:这是新介绍给大家的,大家会疑问为什么在前面的几种情况的pstr指针变量都用2 byte空间而到这里就用3 byte空间了呢?这是KeilC的一个系统内部处理,在 KeilC中一个指针变量最多占用3 byte空 问,对于没有声明指针指向存储空间类型的指针,系统编译代码时都强制加载一个字节的指针类型分辩值。具体的对应关系可以参考KeilC 的 help 中 C51 Users Guide 。第6种情况:uchar * pstr;pstr=tmp;这是最直接最简单的指针变量声明,但他的效率也最低。

8、还是那句话,大家一起说 好吗!编译后的汇编代码如下。MOV DPTR, #0x000A ;0x000A 0x000C是在外ram区分配的pstr指针变量地址 空间MOV A, #0x01MOV DPTR, AINC DPTRMOV DPTR, #0x000AMOV A, #tmp(0x00MOV DPTR, AINC DPTRMOV A, #tmp(0x00MOVX DPTR, A这种情况很类似第5种和第3种情况的组合,既把pstr分配在外ram空间了又增 加了指针类型的分辨值。小结一下:大家看到了以上的6种情况,其中效率最高的是第2种情况,既可以正确访问ram区又节约了代码,效率最差的是第 6种,但不是说大家只使用第2种方式就可以了,还要因情况而定,一般说来应用51系列的系统架构的内部ram资源都很紧张,最好大家在定义函数内部或程序段内部的局部变量使用内ram,而尽量不要把全局变量声明为内ram区中。所以对于全局指针变量我建议使用第3种情况,而对于局部的指针变量使用第 2种方式。C51是很灵活的,也很好理解和使用,但要成为笑傲江湖的一代高手还是要多想多练,没有实际项目的锻炼是不容易提高的。希望这篇文章对大家一点用处

展开阅读全文
相关资源
相关搜索

当前位置:首页 > 商业/管理/HR > 营销创新

电脑版 |金锄头文库版权所有
经营许可证:蜀ICP备13022795号 | 川公网安备 51140202000112号