zoukankan      html  css  js  c++  java
  • 低字节序和高字节序相互转换(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 }
  • 相关阅读:
    转:孟岩老大的忠告谈谈如何写技术文章
    base html / div / css / HTML / DIV / CSS
    js Connection
    db oracle config
    UNIX + OS IBM AIX 5L HACMP
    JAVA EE JSP collection
    地址和指针的概念
    全局变量
    地址和指针的概念
    内存数组的存储
  • 原文地址:https://www.cnblogs.com/lyghost/p/5148885.html
Copyright © 2011-2022 走看看