【合宙】Lua 5.3 十六进制转换为 IEEE754 float 浮点数

例子1

function hex_to_float(hex)
    local i = tonumber(hex, 16) -- 将十六进制数转换为整数
    local s = ((i >> 31) == 0) and 1 or -1 -- 提取符号位
    local e = (i >> 23) & 0xFF -- 提取指数部分
    local m = (e == 0) and (i & 0x7FFFFF) << 1 or (i & 0x7FFFFF) | 0x800000 -- 提取尾数部分
    return s * (2 ^ (e - 127)) * (m / 8388608.0) -- 计算浮点数
end

local hex_string = "42F63D70"
local result = hex_to_float(hex_string)
print(result) -- 应该输出接近 123.12 的值

例子2

function hex_to_float(hex)  
    local i = tonumber(hex, 16) -- 将十六进制数转换为整数  
    local s = (i >> 31) == 0x80000000 and -1 or 1 -- 提取符号位  
    local e = (i >> 23) & 0xFF -- 提取指数部分  
    local m  
    if e == 0 then  
        m = i & 0x7FFFFF -- 当指数为0时,尾数不包含隐藏的1  
    else  
        m = (i & 0x7FFFFF) | 0x800000 -- 否则,添加隐藏的1  
    end  
    -- 计算浮点数值  
    local result  
    if e == 0xFF then  
        -- 处理 NaN 和无穷大  
        if m ~= 0 then  
            -- NaN  
            result = 0/0  
        else  
            -- 无穷大  
            result = s == 1 and math.huge or -math.huge  
        end  
    else  
        -- 正规化浮点数  
        result = s * (m / 2^23) * (2 ^ (e - 127))  
    end  
    return result  
end  
  
local hex_string = "42F63D70"  
local result = hex_to_float(hex_string)  
print(result) -- 应该输出接近 123.12 的值
  • 10
    点赞
  • 8
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值