Memory Model:用鼠标点击Memory Model的下拉箭头,会有3个选项:
Small:变量存储在内部RAM里;
Compact:变量存储在外部RAM里,使用页8位间接寻址;
Large:变量存储在外部RAM里,使用16位间接寻址;
我们一般使用Small来存储变量,就是说单片机优先把变量存储在内部RAM里,如果内部RAM不够了,才会存到外部去。
Compact的方式要自己通过程序来指定页的高位地址,编程比较复杂,如果外部RAM很少,只有256个字节,那么对该256个字节的读取就比较快,用MOVX @Ri,A 或MOVX A,@Ri指令。如果超过256字节,那么要不断地进行切换的话,就比较麻烦。Compact模式适用于比较少的外部RAM的情况。
Large模式,是指变量会优先分配到外部RAM里,用MOVX A,@DPTR或MOVX @DPTR,A来读取。
要注意的是,3种存储方式都支持内部256字节和外部64k字节的RAM。区别是变量的优先(或默认)存储在哪里的区别。除非你不想把变量存储在内部RAM,才使用后面的Compact,Large模式。因为变量存储在内部RAM里,运算速度比存储在外部RAM要快的多,大部分的应用都是选择Small的模式。
使用Small的模式:也不是说变量就不可以存储在外部,一样可以存储在外部,只是你要指定,比如:
unsigned char xdata a; 那么变量a就存储在外部的RAM。
unsigned char a; 变量存储在内部RAM。
使用Large的模式:
unsigned char xdata a; 那么变量a就存储在外部的RAM。
unsigned char a;变量存储在外部RAM。
这就是区别,就是说这几个选项只是影响没有特别指定变量的存储空间的时候,默认存储在哪里,比如上面的变量定义unsigned char a。
KEIL编译出错和Memory Model选择
在输出设置里面target--->memorymodel选择如图所示
Build target 'Target 1'
compiling main.c...
linking...
*** ERROR L107: ADDRESS SPACE OVERFLOW
SPACE: DATA
SEGMENT: ?DT?MAIN
LENGTH: 0024H
*** ERROR L105: PUBLIC REFERS TO IGNORED SEGMENT
SYMBOL: RECEIVEDFLAG
SEGMENT: ?DT?MAIN
*** ERROR L105: PUBLIC REFERS TO IGNORED SEGMENT
SYMBOL: DISPBUF
SEGMENT: ?DT?MAIN
*** ERROR L105: PUBLIC REFERS TO IGNORED SEGMENT
SYMBOL: CHULI
SEGMENT: ?DT?MAIN
*** ERROR L105: PUBLIC REFERS TO IGNORED SEGMENT
SYMBOL: UCRECEIVEDINDEX
SEGMENT: ?DT?MAIN
Program Size: data=106.1 xdata=0 code=4870
Target not created
CPU是STC89C52,编译出错怎么解决。
还有我应该写好程序后应该怎么样处理Memory Model这个选项卡?
因为我在Small模式下面编译成功了以后,我在里面加了一些程序,空间不够了提示,我就把它改为了PDATA,然后编译通过,但是程序就出错了,一直在主函数的while(flag)里面循环,即使我没有给flag设置成1,他照样能进去,而且还循环了。卡在在里面了。
我不明白我应该怎么样解决这个问题,请教!
改成XDATA,外部存储区。
ERROR L107: ADDRESS SPACE OVERFLOW
是地址空间溢出
PDATA也没多少,因为特殊功能半区里很多是不能占用的。
没必要的不要设置成静态变量
追问改成XDATA是能编译通过,不过我听别人说一般这个都是默认的么,改这个对CPU有没有要求啊,
回答 外部存储区,AT的片子得加存储片子,STC的直接做到芯片里了。看你买的什么芯片。
KEIL 没破解有2K限制,你程序超过2048了,看是不是这个原因。
追问你是指code=4870吧?这个没有问题。