精确浮点数转换为byte字节,byte字节转换为精确浮点数

/**
     * 浮点转换为字节
     * @param f
     * @return
     */
    public static byte[] float2byte(float f) {
        // 把float转换为byte[]
        int fbit = Float.floatToIntBits(f);
        
        byte[] b = new byte[4];  
        for (int i = 0; i < 4; i++) {  
            b[i] = (byte) (fbit >> (24 - i * 8));  
        } 
        // 翻转数组
        int len = b.length;
        // 建立一个与源数组元素类型相同的数组
        byte[] dest = new byte[len];
        // 为了防止修改源数组,将源数组拷贝一份副本
        System.arraycopy(b, 0, dest, 0, len);
        byte temp;
        // 将顺位第i个与倒数第i个交换
        for (int i = 0; i < len / 2; ++i) {
            temp = dest[i];
            dest[i] = dest[len - i - 1];
            dest[len - i - 1] = temp;
        }
        return dest;
        
    }
    /**
     * 字节转换为浮点
     * @param b 字节(至少4个字节)
     * @param index 开始位置
     * @return
     */

方法一:
    public static float byte2float(byte[] b, int index) {  
        int l;                                           
        l = b[index + 0];                                
        l &= 0xff;                                       
        l |= ((long) b[index + 1] << 8);                 
        l &= 0xffff;                                     
        l |= ((long) b[index + 2] << 16);                
        l &= 0xffffff;                                   
        l |= ((long) b[index + 3] << 24);                
        return Float.intBitsToFloat(l);                  
    }

方法二:

public static float getFloat(byte[] b) { 
        int accum = 0; 
        accum = accum|(b[0] & 0xff) << 0;
        accum = accum|(b[1] & 0xff) << 8; 
        accum = accum|(b[2] & 0xff) << 16; 
        accum = accum|(b[3] & 0xff) << 24; 
        return Float.intBitsToFloat(accum); 
    }

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值