随笔 - 72, 评论 - 94, 访问 - 421667

导航


  • 访问:421667次
  • 积分:768分
  • 排名:第15名
  • 随笔:72篇
  • 评论:94条

随笔分类

随笔档案

相册

最新评论

阅读排行榜

评论排行榜

好饱 阅读(10505) 评论(1)

 

这个例子展示了如何转换整形数字的字节顺序,该方法可以用来在little-endian和big-endian之间转换。

说明:Windos(x86,x64)和Linux(x86,x64)都是little-endian操作系统

Big-Endian:一个WORD中的高位的Byte放在内存中这个WORD区域的低地址处。

Little-Endian:一个WORD中的低位的Byte放在内存中这个WORD区域的低地址处。

 

 

[C#]

 

// 翻转字节顺序 (16-bit)
public static UInt16 ReverseBytes(UInt16 value)
{
  return (UInt16)((value & 0xFFU) << 8 | (value & 0xFF00U) >> 8);
}

 

 

[C#]

 

// 翻转字节顺序 (32-bit)
public static UInt32 ReverseBytes(UInt32 value)
{
  return (value & 0x000000FFU) << 24 | (value & 0x0000FF00U) << 8 |
         (value & 0x00FF0000U) >> 8 | (value & 0xFF000000U) >> 24;
}

 

 

[C#]

 

// 翻转字节顺序 (64-bit)
public static UInt64 ReverseBytes(UInt64 value)
{
  return (value & 0x00000000000000FFUL) << 56 | (value & 0x000000000000FF00UL) << 40 |
         (value & 0x0000000000FF0000UL) << 24 | (value & 0x00000000FF000000UL) << 8 |
         (value & 0x000000FF00000000UL) >> 8 | (value & 0x0000FF0000000000UL) >> 24 |
         (value & 0x00FF000000000000UL) >> 40 | (value & 0xFF00000000000000UL) >> 56;
}

 

 


发表评论
切换编辑模式