一、内部RAM:共256个单元,用户运用前128个单元,用于寄存可读写数据,后128个单元被专用寄存器占用。
前128单元详细分为:
1.作业寄存器区:共4个组,每组为8个存储单元,即00H-07H,08H-0FH,10H-17H,18H-1FH,详细挑选哪一个由程序状态字(PSW)中的RS1和RS0的组合决议(在此我就不展开了,呵呵……)
2.位寻址区:20H-2FH,共16个单元,每一位能够进行位寻址(16*8=128个位地址),便是每一个触发位,便是bit能够寻址
3.便笺区:从30H-7FH,共80个单元,用于寄存用户数据或作仓库区运用。
4.从80H-FFH为专用寄存器占用,其间还离散的散布SFR(21个特别功用寄存器)
二、256B
其间00H~7FH
可分为3个区域:
00H~1FH 是通用寄存器区
20H~2FH 是位寻址区
30H~7FH 是用户RAM区
80H~FFH是特别功用寄存器区
三、AT89S51单片机的ram,只要128字节,地址规模:00H~7FH。
SFR不是RAM,是特别功用寄存器,地址规模:80H~FFH,SFR在其间离散散布着。
AT89S52单片机的ram,就有256字节,地址规模:00H~FFH。
SFR,特别功用寄存器,仍然在地址规模:80H~FFH。
两者的地址重叠了,差异办法如下:
对80H~FFH直接寻址,便是读写SFR,特别功用寄存器;
对80H~FFH直接寻址,便是读写RAM。
先说说这几个词是什么意思:
1,DATA,51的内部RAM,只要128B(字节)巨细,不管是最新的什么增强型单片机;
2,XDATA,外部RAM,只能运用MOVX寻址
3,CODE,代码区,便是你的代码的巨细,AT89C51为4K,C52为8K等,增强型的有更多的挑选。
然后阐明一下,几种RAM的差异:
1,DATA,也是上面1说到的DATA RAM,占51的128B;
2,IDATA,巨细也为128B,与DATA构成256字节的内存(如AT89C52)
3,PDATA,外部RAM的前256B(便是一个页的巨细),是XDATA的一部分;
4,XDATA,外部RAM
所以你的那个单片机的1280B,其实组成为:
DATA :128B
IDATA:128B
XDATA:1024B
所以你的问题,“运用片内RAM”打勾仅仅软件仿真用的;你的XDATA用了758B,阐明你特意用XDATA关键字定了这么大的内存,比方大数组或许内存形式时,运用了lager形式,那么编译器会主动把超出的部分放到XDATA里,我猜你应该是这儿挑选了lager形式,不过你的内容这么大,也只能挑选lager形式。