DWORD WORD到INT的转换

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

首先,若是是在网络传输、消息解析的状况下,要注意一下网络传送使用的是大端仍是小端模式,这影响到咱们的高低位的传输顺序数组


 WORD&&DWORD

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

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

  Byte:8位.net


解析方式

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

//转换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.下面举得栗子,我不会本身为难本身,搞十几位数,全部都是二位数,全部只用一个字节,且最高依然表明符号位。blog

& 与运算符

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

| 或运算符

或运算符就至关于||, 固然也是按位去或的,当且仅当两个对应的位置都是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.这个结果你们能够去验证下~~~class

^异或运算符

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

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

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

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

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

相关文章
相关标签/搜索