这个例子展示了如何转换整形数字的字节顺序,该方法可以用来在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 }