大小端含义
小端:低位存低地址,高位存高地址,例0x11223344
低地址 | 高地址 | ||
---|---|---|---|
44 | 33 | 22 | 11 |
大端:低位存高地址,高位存低地址,0x11223344
低地址 | 高地址 | ||
---|---|---|---|
11 | 22 | 33 | 44 |
用程序实现大小端的判断
int main()
{
int n = 1;
//小端 01 00 00 00
//大段 00 00 00 01
if ((char)n == 1)//强制类型转为char,即取第一个字节,如果是01就是小端
{
printf("小端");
}
if ((char)n == 0)
{
printf("大端");
}
return 0;
}
运行结果
vs2022是小端存储
下面用一道题来加深理解
已知:小端存储,问:以下代码输出什么
int main()
{
int a[4] = { 1,2,3,4 };
int* p1 = (int*)(&a + 1);
int* p2 = (int*)((int)a + 1);
printf("%#x %#x", p1[-1], *p2);
return 0;
}
思路
int a[4] = { 1,2,3,4 };
小端模式中,这个整形数组在内存中是这样存储的
int* p1 = (int*)(&a + 1);
&a表示整个数组的地址,&a+1就表示跳过了整个数组,因此这条语句过后p1指向数组a的下一位。
int* p2 = (int*)((int)a + 1);
a是数组名,表示数组a 的首元素地址,经过int强制类型转换后,地址变为整形,因此+1就相当于直接在地址上+1(地址的数值加1,即右移一个字节),然后再将这个整形转化为int指针。因此在这条语句过后p2指向数组a的第二个元素。
printf("%#x %#x", p1[-1], *p2);
其中p1[-1]就相当于* (p1-1),并且p1的类型为整形指针,所以要左移4位
并且解引用后读取4位,因此以16进制表示就是0x00000004,所以打印出来就是0x4
同样,p2是整形指针,所以解引用时要读取4位
所以以16进制可以表示为0x02000000,打印出来就是0x2000000