zoukankan      html  css  js  c++  java
  • 实现大小端之间的转换宏,包括32位和64位的数

    这里利用汇编的思想

    思路:1、大端转换为小端模式就将大端的高位和低位的值进行交换,先将高位清零然后右移到低位,低位清零左移到高位,然后两者再进行或(|)运算,就得到小端模式

            2、小端转换为大端模式就将小端的高位和低位的值进行交换,先将高位清零然后左移到高位,低位清零右移到低位,然后两者再进行或(|)运算,就得到大端模式

    主要注意的是机器的位数:决定了移位数以及清零时高低位所使用的数的大小和位数

    大端转换成小端模式:

    32位:

    #define swap32Big2Little(x)    (   ( (x)&(0x0000ffff) ) << 32 |  ( (x)&(0xffff0000) >> 32   )

    64位:

    #define swap32Big2Little(x)    (   ( (x)&(0x00000000ffffffff) ) >> 64 |  ( (x)&(0xffffffff00000000) >>64  )

    小端到大端是一样的,因为以上的宏主要是实现了高位和低位的相互交换

  • 相关阅读:
    c#数据结构与算法
    学习资源---.NET
    怎样完全删除sqlserver
    树,森林 二叉树之间转化 原理
    ref 和out 区别
    GridView批量删除记录、全选及弹出确认对话框
    .NET基础 小记--------2013.8.10
    Xml 读写
    同步 异步 区别
    委托学习
  • 原文地址:https://www.cnblogs.com/bingdaocaihong/p/6960947.html
Copyright © 2011-2022 走看看