整型变量和字节数组的 转换

来源:互联网 发布:sql2012还原数据库 编辑:程序博客网 时间:2024/05/17 08:37

public class IntByteConvertor {
 
 public static byte[] int2Byte(int intValue){
  byte[] b=new byte[4];
  for(int i=0;i<4;i++){
   b[i]=(byte)(intValue>>8*(3-i) & 0xFF);
   //System.out.print(Integer.toBinaryString(b[i])+" ");
   //System.out.print((b[i]& 0xFF)+" ");
  }
  return b;
 }
 public static int byte2Int(byte[] b){
  int intValue=0;
  for(int i=0;i<b.length;i++){
   intValue +=(b[i] & 0xFF)<<(8*(3-i));
   //System.out.print(Integer.toBinaryString(intValue)+" ");
  }
  return intValue;
 }
 public static void main(String[] args) {
  System.out.println(byte2Int(int2Byte(1000)));
 }
}

----------------------------------------------------------------------------------

    JAVA里边对于byte变量,假如操作中有int操作数,默认会将byte隐式转换为int变量,而转换成的int变量高24位全部为1, 比如 1000 的四个字节是 0x00H, 0x00H,  0x03H, 0xE8 , 转换后存到字节数组中是完全正确的;不过逐个打印出来的时候,会隐式转换为int ,如下
0x00000000H , 0x00000000H, 0xFFFFFF03H, 0xFFFFFFE8,  显示出来就是 0 , 0 , 3, -24 

    接下来,在将byte数组转换为int变量的时候,假如直接用移位操作就会有麻烦,因为高位都是FFFFFF,所以需将隐式转换生成的FFFFFF消掉,有一招就是每个字节和0xFF相与,然后再移位,最后把各步产生的结果相加得到原始的int变量。

int转换为字节数组的我就不细说了,这里把字节数组转换为int的过程列出来

如下所示: 【1000 为例】
============================================================

原字节数组 : 0x00H, 0x00H,  0x03H, 0xE8
进行位运算的时候隐式转换为int : 0x00000000H , 0x00000000H, 0xFFFFFF03H, 0xFFFFFFE8 

1.  0x00000000H  与0xFF相与=> 0x00000000H   =>左移24位 =>   0x00000000H 
2.  0x00000000H  与0xFF相与=> 0x00000000H   =>左移16位 =>   0x00000000H 
3.  0xFFFFFF03H 与0xFF相与=> 0x00000003H  => 左移8位 =>    0x00000300H  
4.  0xFFFFFFE8H 与0xFF相与=> 0x000000E8H  => 左移0位 =>    0x000000E8H 

将1,2,3,4 所得结果相加就是我们的int变量了
结果:0x000003E8H ==> 十进制 1000
=====================================================

呵呵,就是这样搞定的!


0 0
原创粉丝点击