Ⅰ 单片机C语言中: 定义 int idata i;和 idata int i 的区别
你的说法是不对的,C51中变量的存储器类型有code,data,idata,xdata,bdata,pdata这几种。
code:定义的变量在程序存储区域,64Kbyte范围,变量为只读。
data:定义的变量在00H~7FH的RAM,128byte范围,变量可读写。
idata:定义的变量在00H~FFH的RAM,256byte范围,变量可读写。
bdata:定义的变量在20H~2FH的RAM,16byte范围,变量可读写。
xdata:定义的变量在扩展的外部存储区,64Kbyte范围,变量可读写。
pdata:分页寻址外部存储区,256byte范围
Ⅱ keil C51里idata,bdata.........这些关键字都是什么意思
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, 建议少用。但也有他的优点,具体用法属于中级问题,这里不提。
startup.a51的作用,和汇编一样,在C中定义的那些变量和数组的初始化就在startup.a51中进行,如果你在定义全局变量时带有数值,如unsigned char dATa xxx="100";,那startup.a51中就会有相关的赋值。如果没有=100,startup.a51就会把他清0。(startup.a51==变量的初始化)。 这些初始化完毕后,还会设置SP指针。对非变量区域,如堆栈区,将不会有赋值或清零动作。
有人喜欢改startup.a51,为了满足自己一些想当然的爱好,这是不必要的,有可能错误的。比如掉电保护的时候想保存一些变量, 但改startup.a51来实现是很笨的方法,实际只要利用非变量区域的特性,定义一个指针变量指向堆栈低部:0xff处就可实现。, 为什么还要去改? 可以这么说:任何时候都可以不需要改startup.a51,如果你明白它的特性。
bit
是在内部数据存储空间中 20H .. 2FH 区域中一个位的地址,这在DATA的20H以后以字节形式出现,可互相参照。另外加上8051 可寻址 的SFR,但刚刚试过,只是00H--7FH起作用,也就是说当数据有变化时颜色变红,以后的从80H到--FFH就不是位寻址区了,是位寻址的特殊寄存器,如涉及到了可位寻址的那11个当然会有反应。
复位后,程序计数器PC的内容为0000H,内部RAM各单元的值不确定。
各功能寄存器的复位值如下:
堆栈指针SP的复位值为07H,累加器ACC、寄存器B的复位值为00H,数据指针DPTR的复位值为0000H,而p0、p1、p2、p3四个口的复位值为0FFH。其他SFR如PSW、TCON、TMOD、TL0、TH0、TL1、TH1的复位值也为00H。
wave中是低128字节和高128字节(0-7FH),低128字节是片内RAM区,高128字节(80-FFH)是SFR(特殊功能寄存器)bit则是位于低128字节的20H .. 2FH 区域,即data的20H .. 2FH 区域
code是在 0000H .. 0FFFFH 之间的一个代码地址。
我用
ORG 5000H
TAB: DB 22H,3BH,43H,66H,5H,6DH,88H后,
CODE从5000H开始以后变成DB各位
data
是在 0 到 127 之间的一个数据存储器地址,或者加 128 .. 255 范围内的一个特殊功能寄存器(SFR)地址。两者访问的方式不同。实际上由于PSW的复位设置PSW.3=RS0和PSW.4=RS1皆为0,所以通用工作寄存器区就是第0区,所以data的00--07H部分是与REG栏中的R0--R7对应的。以后的则仅代表低128字节的内部RAM。
idata
是 0 to 255 范围内的一个 idata 存储器地址
idata与data重合低128字节,有的地方只有DATA表示256字节的片内RAM,
xdata 是 0- 65535 范围内的一个 xdata 存储器地址。
指针类型和存储区的关系详解
一、存储类型与存储区关系
data ---> 可寻址片内ram
bdata ---> 可位寻址的片内ram
idata ---> 可寻址片内ram,允许访问全部内部ram
pdata ---> 分页寻址片外ram (MOVX @R0) (256 BYTE/页)
xdata ---> 可寻址片外ram (64k 地址范围FFFFH)
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 * xdata pstr;
pstr="tmp";
如果详细看了第1种情况的读者发现这种写法和第1种很相似,是的,同第1 种情况一样这样也是有bug的,但是这次是把pstr分
配到了外ram区了。编译后的汇编代码如下。
MOV DPTR, #0x000A ;0x000A是在外ram区分配的pstr指针变量的地址空间
MOV A, #tmp(0x00)
MOVX @DPTR, A
第5种情况:
uchar * data pstr;
pstr="tmp";
大家注意到"*"前的关键字声明没有了,是的这样会发生什么事呢?下面这么写呢!对了用齐豫的一首老歌名来说就是 “请跟我
来”,请跟我来看看编译后的汇编代码,有人问这不是在讲C51吗? 为什么还要给我们看汇编代码。C51要想用好就要尽可能提升C51
编译后的效率,看看编译后的汇编会帮助大家尽快成为生产高效C51代码的高手的。还是看代码吧!
MOV 0x08, #0X01 ;0x08-0x0A是在内ram区分配的pstr指针变量的地址空间
MOV 0x09, #tmp(0x00)
MOV 0x0A, #tmp(0x00)
注意:这是新介绍给大家的,大家会疑问为什么在前面的几种情况的pstr指针变量都用2 byte空间而到这里就用3 byte空间了
呢?这是KeilC的一个系统内部处理,在KeilC中一个指针变量最多占用 3 byte空间,对于没有声明指针指向存储空间类型的指针,
系统编译代码时都强制加载一个字节的指针类型分辩值。具体的对应关系可以参考KeilC的help中C51 User's Guide。
第6种情况:
uchar * pstr;
pstr="tmp";
这是最直接最简单的指针变量声明,但他的效率也最低。还是那句话,大家一起说好吗!编译后的汇编代码如下。
MOV DPTR, #0x000A ;0x000A-0x000C是在外ram区分配的pstr指针变量地址空间
MOV A, #0x01
MOV @DPTR, A
INC DPTR
MOV DPTR, #0x000A
MOV A, #tmp(0x00)
MOV @DPTR, A
INC DPTR
MOV A, #tmp(0x00)
MOVX @DPTR, A
这种情况很类似第5种和第3种情况的组合,既把pstr分配在外ram空间了又增加了指针类型的分辨值。
Ⅲ 请问www.bggidata.org 查询编码 BJ101467189的翡翠手镯是真货吗值多少价
不要给个编号,让人四处查询,就算查到证书,看到证书上镯子的照片,又能怎么样呢?
证书照和实物是有偏差的,对于评估翡翠手镯的价格或品质意义不大。手镯是需要全面看清楚实物才能判断的。
建议楼主把翡翠手镯拿到自然光下拍几张清晰照片上传上来,我才能给你详细点评。
示范:
Ⅳ www.bggidata.org 宝石鉴定货号:BJ101810323
您好
可以在官网上查询此证书详细信息及证书照
此件绿玉髓吊坠,
国标中对于玉髓的色泽优化不做鉴别,都按玉髓出具结论
这款绿色部分为优化,但符合国标,色泽均一
配饰925银价值不高
一般商场打折抽奖销售居多
实价小几百 市场价三四百区间
商场标价虚高,不足信
希望回答可以帮助您
Ⅳ Keil中data和idata,pdata,xdata以及code的区别
使用软件之前,要养成阅读软件帮助的良好习惯,而不是到处东问西问!
Cx51的存储类型:Cx51通过以下的关键字定义了不同的存储类型,从而确保能够访问到51架构的全部存储空间。
code:访问程序存储器(默认仅限于标准51能够寻址的64kB空间内),生成的代码主要通过 MOVC @A+DPTR实现。
data:访问可直接寻址的片内存储器(标准51的低128字节),从而实现对变量最高速的访问。
idata:访问间接寻址的片内存储器(标准51的256字节)。
bdata:访问位寻址的片内存储器(标准51中从20H开始的16字节),支持位+字节的混合访问模式。
xdata:访问外部数据存储器(默认仅限于标准51能够寻址的64kB空间内),生成的代码主要通过MOVX @A+DPTR实现。
far:扩展的RAM及ROM访问方式,最大支持16MB寻址空间,至于生成的代码方式则取决于用户自定义的访问程序或特定的芯片类型(例如恩智浦的80C51MX、Dallas390等)。
pdata:访问当前页面内的外部数据存储器(256字节),生成的代码主要通过MOVX @Ri实现。
Ⅵ C51中的data和idata有什么区别,谢谢了
1、作用机理不一样:
data:直接寻址的片内RAM区低128B(00H~7FH)。
idata::单片机间接访问的片内RAM区,允许访问全部片内RAM。
2、使用的方向不一样:
data:计算机中程序、文稿、数字、图像、声音等信息。
idata:idata是51系列单片机能识别的存储器类型之一,固定指前面0x00-0xff的256个字节的片内RAM,其中前128字节和data的128字节完全相同,只是因为访问的方式不同。
(6)idta证书扩展阅读:
C51中的data和idata的应用方向:
data:直接寻址的片内RAM区低128B(00H~7FH)。
bdata:片内RAM的可位寻址区(20H~2FH),允许字节和位混合访问。
idata:单片机间接访问的片内RAM区,允许访问全部片内RAM。
pdata:Ri间接访问的片外RAM的低256B(00H~FFH)。
xdata:用DPTR间接访问的片外RAM,允许访问全部64KB片外RAM(0000H~FFFFH)。
code:单片机的64KB程序存储区ROM。
data:所谓数据就是描述事物的符号。在我们的日常生活中,数据无所不在。数字、文字、图表、图象、声音等都是数据。人们通过数据来认识世界,交流信息。dos命令:
计算机用语:在51单片机中,DATA表示data area,数据区。DATA并不是修改日期命令
Ⅶ idata系列是免费安装的吗
是的,所有的idata系列都会免费安装到位的,并且测试安全无误才会交由客户使用的。
Ⅷ 请鉴定翡翠手镯真伪及价格网址www.bggidata.org证书编号bj101778533,价格差
总质量:70.10g
颜色:浅绿色
折射率:1.66(点测)
密 度:3.33
吸收光谱:翡翠特征谱
放大检查:纤维柱粒交织结构
光性:非均质集合体
---
天然翡翠A货手镯
真货无疑
但是,这物件不是冰种
还差的很远。。
只能看到糯种
图片和证书图均不是太清楚
粗略目测
无纹裂情况下
千元以内 不超过1500
实物效果更好一些的话
可以上2000
希望您没有买贵
有不明白的地方请继续追问
还望选为满意回答 谢谢
Ⅸ www.bggidata.org请问北京高德珠宝鉴定研究所的宝石鉴定证书是真的吗
bj101713773有没有这个编码,大概是多少钱
Ⅹ 为什么Keil C中idata不能用,是不是要在哪里设置一下
的确是RAM不够了,因为你没有把堆栈计算进去,所以虽然看起来小于256,但实际已经溢出。
从编译结果来看,你有好几个函数有实体但没有调用,这样是很浪费RAM的,因为KEIL因此会为这些函数中的局部变量都做了保留,相当于变成了全局变量来保存,如果你不想删除这些函数,那就教你个办法,在程序初始化阶段:
i=0;
if(i)
{
...
不需要调用的函数;
...
}
这样就能把RAM省下来了。
记住,嵌入式编程时,任何一个RAM空间都是十分宝贵的,可不能像PC程序那样用啊。一些对性能要求不高的变量,或使用不频繁的变量最好定义到XDATA中去。