比如值为2的
int型
在内存中数据是:00000010 00000000
00000000
00000000
所以如下:
int a=2;
char *ca=(char*)&a;
printf("%d",*ca);
打印出来的是2,也就说低位在前。
-------------------------------------------------------------------------------------
开始说说高位优先和低位优先,我们看如下代码:
int i=10;
那么i在内存中的布局如何哪?
假设内存是从低--->高增长的
在低位优先的硬件里面,内存布局如下:
00001010 00000000 00000000 00000000
而在高位优先的内存中:
00000000 00000000 00000000 00001010
这就是我们经常听说的高位优先,低位优先。
那么我们需要注意什么冬冬勒?
看下面一个程序:
#include <stdio.h>
main()
{
int a=10;
short b;
memcpy(&b,&a,2);
printf("%d\n",b);
}
如果你输出结果为:10,恭喜你,你的内存存储是低位优先,
如果结果为:0呢?恭喜你,你的内存存储是高位优先。
btw:在处理器中总是高位优先。
int i=10;
那么i在内存中的布局如何哪?
假设内存是从低--->高增长的
在低位优先的硬件里面,内存布局如下:
00001010 00000000 00000000 00000000
而在高位优先的内存中:
00000000 00000000 00000000 00001010
这就是我们经常听说的高位优先,低位优先。
那么我们需要注意什么冬冬勒?
看下面一个程序:
#include <stdio.h>
main()
{
int a=10;
short b;
memcpy(&b,&a,2);
printf("%d\n",b);
}
如果你输出结果为:10,恭喜你,你的内存存储是低位优先,
如果结果为:0呢?恭喜你,你的内存存储是高位优先。
btw:在处理器中总是高位优先。
int在32位计算机中占4个字节,主要是想弄清楚这4个字节的在内存中存放的顺序。
1 #include <iostream>
2
3 using namespace std;
4
5 typedef struct int_char
6 {
7 int a;
8 unsigned char *b;
9 };
10
11 int main()
12 {
13 int_char A;
14 int i;
15 //test int;
16 A.a=0x01ab02cd;
17 A.b=(unsigned char *)&A.a;
18 for(i=0;i<4;i++)
19 printf("%02X\n",*(A.b+i));
20 cout<<""<<endl;
21 //test short;
22 short c=0x01ab;
23 A.b=(unsigned char *)&c;
24 for(i=0;i<2;i++)
25 printf("%02X\n",*(A.b+i));
26
27 getchar();
28 return 0;
29 }
输出结果为:
CD
02
AB
01
AB
01
由此可见,int,short均为低字节存在低地址,高字节存在高地址;
16位和32位的数是怎样存储的?——“http://see.xidian.edu.cn/cpp/html/1615.html”
这个链接里面讲的现在32位数存储只剩两种:低位优先(little—endian)和高位优先(big—endian)。
而用哪种模式存储是由CPU决定的,大多数计算机按高位优先顺序存储32位的数,但基于Intel CPU的计算机按低位优先顺序存储32位的数。
我的电脑是采用的CPU是Intel的,这也印证了我之前的结果,先存储低字节再到高字节这种顺序,也就是低字节存在低地址,高字节存在高地址。
引申:
- 内存如此安排,这样便也可以理解,用类型强制转换时,内存的读取;如int强制转换为short,那么short就只取int中的两个低字节。