小结:
- 指针的值是所指元素分配内存大小,逻辑地址内存单元的地址
- 内存单元里面是所指元素的内容,以补码二进制存储,方便起见,化为16进制
- 要想弄懂,必须知道元素在计算机内存是咋存储的,也就是内存影像图
- 类型强转就是对所能读取内存单元的改变,指类在内存作用是,地址单元的映射长度
-
short a = 1如图1 int b = 32; 2 short * p_short = &a 3
数值 | 内存单元地址 |
0x1 | 0xffeecca0 |
0x0 | 0xffeecca1 |
0xf | 0xffeecca2 |
0x1 | 0xffeecca3 |
0x0 | 0xffeecca4 |
0x0 | 0xffeecca5 |
0x0 | 0xffeecca6 |
oxa | |
oxc | |
oxc | |
oxe | |
0xe | |
0xf 0xf | 0xffeeccae |
int main()
{short x;
char x0,x1;
x=0x1122;
printf("x = 0x%x\n",&x);
printf("little= 0x%x\n",((char *)&x)+0); //每次指针加一,相当移动指类 char的大小
printf("big = 0x%x\n",((char *)&x)+1);
printf("little = 0x%x\n",&(((char *)&x)[0]));//目的与上面一样,不过一个类似移动指针间接访问
//一个用类似知道数组首地址进行的直接访问
printf("big = 0x%x\n",&(((char *)&x)[1]));
x0=((char *)&x)[0]; //低地址单元,相当知道了首元素地址,指针的匿名访问
x1=((char *)&x)[1]; //高地址单元
printf("x0=0x%x,x1=0x%x",x0,x1);// 若x0=0x11,则是大端; 若x0=0x22,则是小端......
return 0;
}
<span style="font-size:24px;">int main()
{
short x;
char x0,x1;
x=0x1122;
printf("x = 0x%x\n",&x);
printf("little= 0x%x\n",((char *)&x)+0); //每次指针加一,相当移动指类 char的大小
printf("big = 0x%x\n",((char *)&x)+1);
printf("little = 0x%x\n",&(((char *)&x)[0]));//目的与上面一样,不过一个类似移动指针间接访问
//一个用类似知道数组首地址进行的直接访问
printf("big = 0x%x\n",&(((char *)&x)[1]));
x0=((char *)&x)[0]; //低地址单元,相当知道了首元素地址,指针的匿名访问
x1=((char *)&x)[1]; //高地址单元
printf("x0=0x%x,x1=0x%x",x0,x1);// 若x0=0x11,则是大端; 若x0=0x22,则是小端......
return 0;
}
</span>