51单片机C语言几个数组定义的区别(精).docVIP

51单片机C语言几个数组定义的区别(精).doc

  1. 1、本文档共7页,可阅读全部内容。
  2. 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
  3. 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  4. 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
  5. 5、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
  6. 6、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们
  7. 7、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
  8. 8、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
51单片机C 语言几个数组定义的区别 这样三个句子 const uchar a[12]={...........}; char idata time[4]={...........}; uchar code table[20]={...........}; const idata code 这三个是什么作用?句子是什么意思? const 表示本数组不可修改 数组为常量数组 code 表示本数组生成后是在ROM 区中 同样不可修改 idata 表示数组生成后在在0x00~0xff的256个RAM 中,使用指针寻址 具体的参考下面 data,bdata,idata,pdata,xdata,code 存储类型与存储区 bit 是在内部数据存储空间中 20H .. 2FH 区域中一个位的地址,或者 8051 位可寻址 SFR 的一个位地址。 code 是在 0000H .. 0FFFFH 之间的一个代码地址。 data 是在 0 到 127 之间的一个数据存储器地址,或者在 128 .. 255 范围内的一个特殊功能寄存器(SFR )地址。 idata 是 0 to 255 范围内的一个 idata 存储器地址。 xdata 是 0 to 65535 范围内的一个 xdata 存储器地址。 指针类型和存储区的关系详解 一、存储类型与存储区关系 data --- 可寻址片内ram bdata --- 可位寻址的片内ram idata --- 可寻址片内ram ,允许访问全部内部ram pdata --- 分页寻址片外ram (MOVX @R0 (256 BYTE/页 xdata --- 可寻址片外ram (64k 地址范围 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 *

文档评论(0)

hkfgmny + 关注
实名认证
文档贡献者

该用户很懒,什么也没介绍

1亿VIP精品文档

相关文档