您的位置:首页 > 编程语言 > C语言/C++

一道题解读“类型强转”在内存中发生了什么

2016-06-12 00:26 423 查看
小结:

 指针的值是所指元素分配内存大小,逻辑地址内存单元的地址
内存单元里面是所指元素的内容,以补码二进制存储,方便起见,化为16进制
     要想弄懂,必须知道元素在计算机内存是咋存储的,也就是内存影像图
类型强转就是对所能读取内存单元的改变,指类在内存作用是,地址单元的映射长度

short   a = 1      如图1
int b = 32;    2
short * p_short = &a3
数值内存单元地址
0x10xffeecca0
0x00xffeecca1
  
0xf0xffeecca2
0x10xffeecca3
0x00xffeecca4
0x00xffeecca5
  
0x00xffeecca6
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>
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签:  c 内存 c语言 指针