C++基础——多字节值与字节序

多字节值与字节序

大于8位(一字节)的值称为多字节量,在内存中存储多字节量有两种方式:

小端:处理器储存多字节值的最低有效字节于较低的内存位置,则该微处理器就是小端处理器;

大端:微处理器储存多字节值的最高有效字节于较低的内存位置,则该处理器为大端处理器。

对于跨平台应用,字节序的两种处理方式

  • 所有数据以文字的方式写入文件;多字节数值以一串十进制数字,每个数字一个的写入,这会浪费磁盘空间。
  • 工具先转换字节序,然后再把转换后的数据写进二进制文件。

字节序的判断

/*
*返回1小端
*返回0是大端
*/

int check_sys()
{
    int i = 1;
    return ((char)&i);
}

整数字节序的转换

typedef unsigned short U16;
typedef unsigned int U32;

U16 swapU16(U16 value) 
{
	return ((value & 0xFF00) >> 8 ) | ( (value & 0x00FF) << 8 );
}

U32 swapU32(U32 value) 
{
	return ( (value & 0x000000FF) << 24 )
		| ( (value & 0x0000FF00) << 8 )
		| ( (value & 0x00FF0000) >> 8 )
		| ( (value & 0xFF000000) >> 24 );
}

浮点数的字节序转换

虽然浮点数有详细的内部结构,其中某些位作为尾数,有些位作为指数,并还有一个符号位,虽然其结构复杂,但仍然可以把浮点数当作整数转成字节序:

typedef unsigned short U16;
typedef unsigned int U32;
typedef float F32;

union  U32F32
{
	U32 m_asU32;
	F32 m_asF32;
};

U32 swapU32(U32 value) 
{
	return ( (value & 0x000000FF) << 24 )
		| ( (value & 0x0000FF00) << 8 )
		| ( (value & 0x00FF0000) >> 8 )
		| ( (value & 0xFF000000) >> 24 );
}

F32 swapF32(F32 value) 
{
	U32F32 u;
	u.m_asF32 = value;
	u.m_asU32 = swapU32(u.m_asU32);
	return u.m_asF32;
}

 

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值