大小端存储模式的判断与转换

大小端存储模式的判断与转换,第1张

大小端存储模式的判断与转换

大小端的理解
  • 大小端模式的介绍
  • 为什么会有大小端存储模式之分
  • 大小端模式的判断
  • 大小端模式的转换

大小端模式的介绍

大端模式:是指一个数据的低位字节序的内容放在高地址处,高位字节序存的内容放在低地址处。
小端模式:是指一个数据的低位字节序内容存放在低地址处,高位字节序的内容存放在高地址处。
例如:0x12345678在内存中的表示形式。

大端模式:

小端模式

为什么会有大小端存储模式之分

在计算机系统中,我们是以字节为单位存放数据的,每个地址单元都对应着一个字节,一个字节为8bit。但在C语言中除了 8 bit 的char之外,还有 16 bit 的 short型,32bit的long型等存在不同的数据类型,另外,对于位数大于8位的处理器,例如16位或者32位的处理器,由于寄存器宽度大于一个字节,那么必然存在着一个如果将多个字节安排的问题。因此就导致了大端存储模式和小端存储模式。

大小端模式的判断

1、

int main()
{
	short st = 0x0001;
	char *p = (char*)&st;
	if(*p == 1)
	{
		printf("第一个字节为:%xn",*p);
		printf("小端n");
	}
	else
	{
		printf("第一个字节为:%xn",*p);
		printf("大端n");
	}
}


2、共用体判断

union un_data
{
	short st;
	char ch[2];
};

int main()
{
	union un_data ud = {0x0001};
	if(ud.ch[0] = 1)
	{
		printf("小端n");
	}
	else
	{
		printf("大端n");
	}
	return 0;
}

大小端模式的转换
union un_data
{
	short st;
	char ch[2];
};

short small_to_big(short x)//小端转大端
{
	union un_data ud;
	ud.st = x;
	char tmp = ud.ch[0];
	ud.ch[0] = ud.ch[1];
	ud.ch[1] = tmp;
	return ud.st;
}
int main()
{
	short a = small_to_big(0x0001);
	char *p = (char*)&a;
	if(*p == 1)
	{
		printf("第一个字节为:%xn",*p);
		printf("小端n");
	}
	else
	{
		printf("第一个字节为:%xn",*p);
		printf("大端n");
	}
}

欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/zaji/5611412.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2022-12-15
下一篇 2022-12-15

发表评论

登录后才能评论

评论列表(0条)

保存