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  )

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

  • 相关阅读:
    huffman编码
    查询选修了全部课程的学生姓名【转】
    java中的内部类
    jdbc技术
    多态
    存储过程,触发器,Mysql权限,备份还原
    sql查询重点
    常用的sql基础
    手动+工具开发动态资源
    Tomcat
  • 原文地址:https://www.cnblogs.com/bingdaocaihong/p/6960947.html
Copyright © 2011-2022 走看看