大小端存储模式的理解、判断和转换

大小端模式的理解

大端模式,是指数据的低字节保存在内存的高地址中,而数据的高字节保存在内存的低地址中,这样的存储模式有点儿类似于把数据当作字符串顺序处理:地址由小向大增加,而数据从高位往低位放;这和我们的阅读习惯一致

小端模式,是指数据的低字节保存在内存的低地址中,而数据的高字节保存在内存的高地址中,这种存储模式将地址的高低和数据位权有效地结合起来,高地址部分权值高,低地址部分权值低

总结:大端模式(低数据高地址) 小端模式(低数据低地址)

大小端存储模式的理解、判断和转换_第1张图片

大小端模式的判断

#include
bool IsBig()    // 判断是否为大端模式
{
	int a = 0x12345678;
	char *p = (char *)&a;
	if(*p == 0x78)     //第一个字节是否为78,若为78则为小端模式,否则,为大端模式
	{
		printf("第一个字节:%x\n",*p);
        return false;   //小端
	}
	else
	{
        printf("第一个字节:%x",*p);
		return true;    //大端
	}

}
int main()
{   
    if(!IsBig()) 
	{
		printf("is little\n");
	}
	else
	{
		printf("is big\n");
	}
}

运行结果:

大小端存储模式的理解、判断和转换_第2张图片

大小端模式的转换

#include
int swap(int n)
{
  
	n = (((n&0xff000000) >>24) | ((n&0x00ff0000) >>8) | ((n&0x0000ff00) <<8) | ((n&0x000000ff) <<24) );
	return n;
}
int main()
{
	int n=0x12345678;
	printf("0x%x\n",n) ;
    printf("0x%x\n",swap(n)) ;  
	return 0;
}

运行结果:

大小端存储模式的理解、判断和转换_第3张图片

你可能感兴趣的:(大小端存储模式的理解、判断和转换)