zoukankan      html  css  js  c++  java
  • DWORD WORD到INT的转换

    最近在做一个有关TCP/TP通信的消息解析,涉及到了这方面的转换,记录一下。

    首先,如果是在网络传输、消息解析的情况下,要注意一下网络传送使用的是大端还是小端模式,这影响到我们的高低位的传输顺序


     WORD&&DWORD

      WORD: 无符号双字节整形(字,16位)

      DWORD:无符号四字节整形 (双字,32位)

      Byte:8位


    解析方式

      采用Java位操作来实现(采用大端方式,故先传递高位,则接收方低位为高)

    //转换DWORD到整型数据
        private int DWORDtoInt(byte[] sourceArr,int start){
            //len=4,inArr为获取到的4位Byte数组
            byte[] intArr=spiltByteArr(sourceArr,start,4);
            return intArr[0]<<24|intArr[1]<<16|intArr[2]<<8|intArr[3];
        }
    
        //转换WORD到整形数据
        private int WORDtoInt(byte[] sourceArr,int start){
            //len=2,intArr为获取到的2为Byte数组
            byte[] intArr=spiltByteArr(sourceArr,start,2);
            return intArr[0]<<8|intArr[1];
        }

    Java 位操作(参考博客:https://blog.csdn.net/lazyman_54/article/details/51283459

    简介

    说到位运算,自然说的全部都是二进制运算,相信大家都比较熟悉,但我还是要说明(啰嗦)一下,java里int型是4个字节,即32位,用二进制表示java里的1就是000……0001,这些都是有符号的数,也就是最高位代表符号位,也就是32位能表示的最大整数是2的32次方-1.下面举得栗子,我不会自己为难自己,搞十几位数,所有都是二位数,所有只用一个字节,且最高依然代表符号位。

    & 与运算符

    与运算符就相当于&&,不同的是,这是按位对比,比如8&9,用十进制的眼光去看简直就瞎了,8&9其实做的运算就是00001000&00001001,然后看到当且仅当两个对应的位置都是1,结果才是1,否则结果为0,那么结果就是00001000,也就是8. 
    那么,这个运算有什么卵用么?答案是当然有啦,比如,我们现在都是用int去做标志位,比如1代表正常,0代表异常,那如果我们用二进制来做的话,不就很爽了么,0001代表正常0010代表异常,0100代表XXX,是不是想想都有点小激动·····

    | 或运算符

    或运算符就相当于||, 当然也是按位去或的,当且仅当两个对应的位置都是0,结果才是0,否则结果是1,那么8|9就是00001000|00001001,结果就是00001001=9。至于这个有什么用,我就不赘述了,有规则就会有用,就这么简单·····

    ~运算符

    非运算符是又得讲一下的,理解起来很容易的,就是按位取反,比如~8对吧,那就是00001000按位取反结果是11110111.前面说了,这是有符号数,也就是最高位代表符号位,也就是~8的结果是一个负数,那么人类第一反应是-8,但结果却不是,那这里简单解析一下,负数的二进制表示方式跟正数不一样,负数有一个反码和补码的概念,这么理解呢?就说-8吧,用二进制表示-8是:11111000,-10的二进制是:11110110. 
    首先-8的绝对值8的二进制是00001000, 求其反码就是11110111,补码(+1)是11111000。那么上面~8的结果11110111是多少呢?我们算一下,先-1得到11110110,然后取反:00001001,得到9,那么~8==9?不是的,是结果的绝对值,因为是负数,所以是-9.这个结果大家可以去验证下~~~

    ^异或运算符

    异或运算是:当运算符两边不同的时候结果为1,两边相同的时候结果为0 这就是传说中的同性相杀,异性相吻。举个例子就是:8^6=1000^0110=1110=14

    >>位移运算符(<<同理)

    位移运算符我们可以简单的理解为乘除法,像左移是除法,向右移是乘法。这个符号位是不移动的,注意下。8>>2大家不要理解为8/2,位移两位就是除以2的2次方也就是8/4.这里注意9>>1的结果是4,即最低位的1会移没了··当然了<<如果结果超过了最大整数能表示的范文,那就·····你懂的。

    >>> 这个应该是无符号的位移运算符

    这个运算符跟>>差不多,不同点是,它移动后高位补0,。好像>>位移后高位也是补0啊,是的,但符号位不移动,而>>>tm符号位都移动了,就是负数一移就正了·····

  • 相关阅读:
    golang 数据结构 优先队列(堆)
    leetcode刷题笔记5210题 球会落何处
    leetcode刷题笔记5638题 吃苹果的最大数目
    leetcode刷题笔记5637题 判断字符串的两半是否相似
    剑指 Offer 28. 对称的二叉树
    剑指 Offer 27. 二叉树的镜像
    剑指 Offer 26. 树的子结构
    剑指 Offer 25. 合并两个排序的链表
    剑指 Offer 24. 反转链表
    剑指 Offer 22. 链表中倒数第k个节点
  • 原文地址:https://www.cnblogs.com/rekent/p/8735661.html
Copyright © 2011-2022 走看看