java 多进制处理

当从文件读取一个字节进行判断是否读取这个字的一半需进行下列处理

1.读出来的字节数据一般为无符号数需进行转化

  转化整形方式: byte & 0xff; 或者 byte + 256) % 256

  如: 1.从文件中读取一个字节值为: -28;

      2.转化为整数为: -28 & 0xff = 228;

      3.在转化为十六进制字符: bytesToHexString(buffer) = "E4";

      4.用下列判断

       if (228 == 0xE4) {
         System.out.println("OK");
       } else {
         System.out.println("NO");
       }

2.根据文件编码方式进行判断。utf-8和unicode 一半字判断字节是不一样的。

  utf8半字节判断
   (c_temp >= 0x80) && (c_temp <0xc0)
  GBK半字节判断 

  (c_temp >= 0xa0)
  uni半字节判断  

  uni偶数

 

java二进制,字节数组,字符,十六进制,BCD编码转换收藏

java二进制,字节数组,字符,十六进制,BCD编码转换2007-06-07 00:17
public static byte[] hexStringToByte(String hex) {
      int len = (hex.length() / 2);
      byte[] result = new byte[len];
      char[] achar = hex.toCharArray();
      for (int i = 0; i < len; i++) {
        int pos = i * 2;
        result[i] = (byte) (toByte(achar[pos]) << 4 | toByte(achar[pos + 1]));
      }
      return result;
}

private static byte toByte(char c) {
      byte b = (byte) "0123456789ABCDEF".indexOf(c);
      return b;
}


public static final String bytesToHexString(byte[] bArray) {
      StringBuffer sb = new StringBuffer(bArray.length);
      String sTemp;
      for (int i = 0; i < bArray.length; i++) {
        sTemp = Integer.toHexString(0xFF & bArray[i]);
        if (sTemp.length() < 2)
          sb.append(0);
        sb.append(sTemp.toUpperCase());
      }
      return sb.toString();
}


public static final Object bytesToObject(byte[] bytes) throws IOException, ClassNotFoundException {
      ByteArrayInputStream in = new ByteArrayInputStream(bytes);
      ObjectInputStream oi = new ObjectInputStream(in);
      Object o = oi.readObject();
      oi.close();
      return o;
}


public static final byte[] objectToBytes(Serializable s) throws IOException {
      ByteArrayOutputStream out = new ByteArrayOutputStream();
      ObjectOutputStream ot = new ObjectOutputStream(out);
      ot.writeObject(s);
      ot.flush();
      ot.close();
      return out.toByteArray();
}

public static final String objectToHexString(Serializable s) throws IOException{
      return bytesToHexString(objectToBytes(s));
}

public static final Object hexStringToObject(String hex) throws IOException, ClassNotFoundException{
      return bytesToObject(hexStringToByte(hex));
}


public static String bcd2Str(byte[] bytes){
      StringBuffer temp=new StringBuffer(bytes.length*2);

      for(int i=0;i<bytes.length;i++){
        temp.append((byte)((bytes[i]& 0xf0)>>>4));
        temp.append((byte)(bytes[i]& 0x0f));
      }
      return temp.toString().substring(0,1).equalsIgnoreCase("0")?temp.toString().substring(1):temp.toString();
}


public static byte[] str2Bcd(String asc) {
      int len = asc.length();
      int mod = len % 2;

      if (mod != 0) {
        asc = "0" + asc;
        len = asc.length();
      }

      byte abt[] = new byte[len];
      if (len >= 2) {
        len = len / 2;
      }

      byte bbt[] = new byte[len];
      abt = asc.getBytes();
      int j, k;

      for (int p = 0; p < asc.length()/2; p++) {
        if ( (abt[2 * p] >= '0') && (abt[2 * p] <= '9')) {
          j = abt[2 * p] - '0';
        } else if ( (abt[2 * p] >= 'a') && (abt[2 * p] <= 'z')) {
          j = abt[2 * p] - 'a' + 0x0a;
        } else {
          j = abt[2 * p] - 'A' + 0x0a;
        }

        if ( (abt[2 * p + 1] >= '0') && (abt[2 * p + 1] <= '9')) {
          k = abt[2 * p + 1] - '0';
        } else if ( (abt[2 * p + 1] >= 'a') && (abt[2 * p + 1] <= 'z')) {
          k = abt[2 * p + 1] - 'a' + 0x0a;
        }else {
          k = abt[2 * p + 1] - 'A' + 0x0a;
        }

        int a = (j << 4) + k;
        byte b = (byte) a;
        bbt[p] = b;
      }
      return bbt;
}

public static String BCD2ASC(byte[] bytes) {
      StringBuffer temp = new StringBuffer(bytes.length * 2);

      for (int i = 0; i < bytes.length; i++) {
        int h = ((bytes[i] & 0xf0) >>> 4);
        int l = (bytes[i] & 0x0f);   
        temp.append(BToA[h]).append( BToA[l]);
      }
      return temp.toString() ;
}


public static String MD5EncodeToHex(String origin) {
            return bytesToHexString(MD5Encode(origin));
        }


public static byte[] MD5Encode(String origin){
      return MD5Encode(origin.getBytes());
}


public static byte[] MD5Encode(byte[] bytes){
      MessageDigest md=null;
      try {
        md = MessageDigest.getInstance("MD5");
        return md.digest(bytes);
      } catch (NoSuchAlgorithmException e) {
        e.printStackTrace();
        return new byte[0];
      }
 
}
//关于byte:      signed byte 把 0x00 ~ 0xff 映射成范围 0~127和 -128~-1      两段,比较简单的办法用 (b+256)%256的办法令其值回到0~255,或者用&0xff并赋给一个int。
 
转至:http://jiqing0311.javaeye.com/blog/317058
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值