低字节序和高字节序相互转换(Little Endian/Big Endian)

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

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

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

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

 

1 // 翻转字节顺序 (16-bit)
2 public static UInt16 ReverseBytes(UInt16 value)
3 {
4   return (UInt16)((value & 0xFFU) << 8 | (value & 0xFF00U) >> 8);
5 }
1 // 翻转字节顺序 (32-bit)
2 public static UInt32 ReverseBytes(UInt32 value)
3 {
4   return (value & 0x000000FFU) << 24 | (value & 0x0000FF00U) << 8 |
5          (value & 0x00FF0000U) >> 8 | (value & 0xFF000000U) >> 24;
6 }
1 // 翻转字节顺序 (64-bit)
2 public static UInt64 ReverseBytes(UInt64 value)
3 {
4   return (value & 0x00000000000000FFUL) << 56 | (value & 0x000000000000FF00UL) << 40 |
5          (value & 0x0000000000FF0000UL) << 24 | (value & 0x00000000FF000000UL) << 8 |
6          (value & 0x000000FF00000000UL) >> 8 | (value & 0x0000FF0000000000UL) >> 24 |
7          (value & 0x00FF000000000000UL) >> 40 | (value & 0xFF00000000000000UL) >> 56;
8 }

 

posted @ 2016-01-21 16:58  Lyghost  阅读(2635)  评论(0编辑  收藏  举报