低字節序和高字節序相互轉換(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 }

 


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM