c语言中的大端模式和小端模式
在学习共用体(联合体 union)的时候,碰到了非常经典的大小端模式问题,以下是个人的见解:
大端模式与小端模式
所有运算的操作数,必须在CPU的內部寄存器才能参与运算对于CPU来说,寄存器才是它真正的储存空间,但是CPU的寄存器的个数以及容量是非常有限的,所以在设计CPU时,必须要有一个它的存储器(Memory),把CPU寄存器中的数据 储存到 储存器memory中,同时也需要把存储器中的数据,加载到寄存器中来。
CPU寄存器 <>存储器==之间的数据交换。
寄存器:是按bits位储存
存储器:是按字节来连续编制
高字节 低字节
R : (4) (3) (2) (1)
M :
___ ___ ___ ___
低地址 高地址
小端模式 : 小存小
存储中的低地址 存储 寄存器中 低字节
(1) (2) (3) (4)
___ ___ ___ ___
低地址 高地址
大端模式 : 小存大
存储器中的低地址 存储 寄存器中的 高字节
(4) (3) (2) (1)
___ ___ ___ ___
低地址 高地址
//以下是判断大小端的两种方法:
#include<stdio.h>//指针方法
int main()
{
int a=260;
int* p=&a;
printf("%d\n",*((char*)p));//这里输出为4
printf("%d\n",*(((char*)p+1));//这里输出为1
return 0;
}
#include<stdio.h>//联合体方法
union test//联合体公用一块内存,并且是最大的成员变量的内存
{
int a;
char b;
};
int main()
{
union test t;
t.a=1;
printf("%d\n",t.b);//如果为1,则是小端,如果为0,则是大端
if(t.b)
{
printf("小端模式!\n");
}
else
{
printf("大端模式!\n");
}
return 0;
}
浙公网安备 33010602011771号