Java byte数组按位转化为long类型

本方法适用于(高位在前,低位在后)的顺序

 public static void main(String[] args) {
        byte[] l = new byte[]{(byte) 0xe7, (byte) 0xf3, (byte) 0x90, (byte) 0x54,
                (byte) 0x39, (byte) 0x6e, (byte) 0x11, (byte) 0x7c,
                (byte) 0x01, (byte) 0xe7, (byte) 0x70, (byte) 0x3c,
                (byte) 0x79, (byte) 0x14, (byte) 0xb5, (byte) 0x67};

        System.out.println(getLong(l,4));
}

 /**
     * @param data 数组
     * @param num 多少个byte相组合成一个数字
     * */
 public static long getLong(byte[] data, int num) {
        long count = 0;
        for (int i = 0; i < data.length / num; i++) {
            int offset = i * num;
            long val = 0;
            for (int j = 0; j < num; j++) {
                long _val =  ((long)(data[offset + num - j - 1] & 0xFF) << j * 8);
                if (val == 0) {
                    val = _val;
                } else {
                    val = val | _val;
                }
            }
            count = count + val;
        }
        return count;
    }

输出:6918358899

本方法适用于(高位在前,低位在后)的顺序


 public static void main(String[] args) {
        byte[] l = new byte[]{(byte) 0xe7, (byte) 0xf3, (byte) 0x90, (byte) 0x54,
                (byte) 0x39, (byte) 0x6e, (byte) 0x11, (byte) 0x7c,
                (byte) 0x01, (byte) 0xe7, (byte) 0x70, (byte) 0x3c,
                (byte) 0x79, (byte) 0x14, (byte) 0xb5, (byte) 0x67};

        System.out.println(getLong(l,4)); }



/**
     * @param data 数组
     * @param num 多少个byte相组合成一个数字
     * */   
  public static long getLong(byte[] data, int num) {
        long count = 0;
        for (int i = 0; i < data.length / num; i++) {
            int offset = i * num;
            long val = 0;
            for (int j = 0; j < num; j++) {
                long _val =  ((long)(data[offset + j] & 0xFF) << j * 8);
                if (val == 0) {
                    val = _val;
                } else {
                    val = val | _val;
                }
            }
            count = count + val;
        }
        return count;
    }

输出:6918358899

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值