十六进制浮点转十进制浮点型

本文介绍了一种从Modbus字节序列中解析浮点数的方法。通过位操作和数学运算,将4个字节的数据转换为IEEE 754标准的浮点数值。文章详细展示了如何提取指数部分和尾数部分,并最终计算出浮点数。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

public static double modbusFloat(byte[] bits) {
        double rtn = 0;
        int flag = 1;
        if (bits.length == 4) {
            int E = bits[0] & 0x80;
            if (E > 0) {
                flag = -1;
            }

            E = ((bits[0] & 0x7F) << 1) + ((bits[1] & 0x80) >> 7);
            // 0x41360000 0 10000010 01101100000000000000000
            double M10 = 0.0;
            for (int i = 1; i <= 7; i++) {
                M10 += (bits[1] >> (7 - i) & 0x01) * Math.pow(2, -1 * i);
            }
            for (int i = 1; i <= 8; i++) {
                M10 += (bits[2] >> (8 - i) & 0x01) * Math.pow(2, -1 * (i + 7));
            }
            for (int i = 1; i <= 8; i++) {
                M10 += (bits[3] >> (8 - i) & 0x01) * Math.pow(2, -1 * (i + 15));
            }

            String data = "" + (1.0 + M10);
            double dVal = Double.parseDouble(data);
            rtn = flag * dVal * (Math.pow(2, E - 127));
        }
        // 00110011001100110100000000010011
        return rtn;
    }

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值