程序存储模式分为大端模式和小端模式。
大端模式:字数据的高字节存放在低地址中,低字节存放在高地址中:
小端模式:字数据的高字节存放在高地址中,低字节存放在低地址中:
一个测试是大端模式还是小端模式的方法:
#include <;
#include <;
int CheckSystem()
{
int *p=NULL;
union check
{
int i;
char ch;
}c;
c.i=1;
return == 1);
}
int main(void)
{
if(CheckSystem())
printf("小端模式");
else
printf("大端模式");
}
输出:
大端模式和小端模式主要在MCU编程是要考虑,在进行MCU编程之前,用上述程序测试一下。
一个奇怪的程序的理解:小端存储
#include <;
#include <;
int main(void)
{
int a[5] = {1,2,3,4,5};
int *p1=(int*)(&a+1);
int *p2=(int*)((int)a + 1);
printf("%X %X %X %X\n",&a,&a+1,(int)a,(int)a+1);
printf("%X %X\n",p1[-1],*p2);
return 0;
}
输出什么?
输出如下:
即:&a == 0x12ff34,(&a+1) == 0x12ff48,((int)a) == 0x12ff34,((int)a +1) == 0x12ff35;
p1指向的是0x12ff48所代表的地址,0x12ff48=0x12ff34+0x14
p2指向的是0x12ff35所代表的地址。
&a即表示a[0]地址,a中各元素地址:
&a[0]==0x12ff34
&a[1]==0x12ff38
&a[2]==0x12ff3c
&a[3]==0x12ff40;
&a[4]==0x12ff44;
内存如下:
可以看出p1指向的实际是a[4]的后面一个内存的地址
而p1[-1]值为5,为a[4],所以p1[-1]等价于p1-1.由于p1指向0x12ff48,所以p1-1指向0x12ff44,也就是a[4]的地址,
所以p1[-1]为5,同理可推断出p1[-2]值为4,p1[-3]值为3,p1[-4]值为2,p1[-5]值为1
再看p2指向的地址为0x12ff35,也就是上图中01后面的那个00所占有的地址,那么*p2指向一个整型值,应该是地址0x12ff35~0x12ff38内的值,为2000000
同理可推断,若int *p2=(int*)((int)a+2);则*p2=20000;若int *p2=(int*)((int)a+3);则*p2=200;若int *p2=(int*)((int)a+4);则*p2=2;
~~~end~~~