int main()
{
int num = 0x12345678;
uint8_t * p = (uint8_t*)#
for (int i=0;i<4;++i)
{
//小端模式,低地址存放低位,p+0 为78,p+1为56,p+2为34,p+3为12,大端刚好想法
printf("0x%02x\n", *(uint8_t *)(p + i));
}
return 0;
}
//假若我们通过UDP协议收到两个表示文本长度的字节,这时是因为收到的是网络字节序,所以需要将其转换成主机字节序(即小端)。下面即模拟了协议解析中的长度字段的解析
//主机字节序,数组地址的大小是反转的
uint8_t m_lengthBuffer[2] = {0x05,0xa0};//假若收到的网络字节序是05 a0,1440
//直接强转,相当于转的0x0000a005 ,其实应该转的是0x000005a0
int l = 0;
//网络字节序 01 02 结果应该是 02 01
for (int i = 1, shift = 0; i >= 0; i--, shift += 8)
{
l |= ((int)m_lengthBuffer[i]) << shift;
}
大小端
最新推荐文章于 2023-05-30 12:02:08 发布