加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 百科 > 正文

c – 将4个原始字节转换为32位浮点

发布时间:2020-12-16 10:10:31 所属栏目:百科 来源:网络整理
导读:我正在尝试从eeprom重构一个32位浮点值. eeprom存储器(0-4)中的4个字节为:B4 A2 91 4D 并且PC(VS Studio)正确地重建它为3.054199 * 10 ^ 8(我知道浮点值应该在那里) 现在我将这个eeprom从8位Arduino中读取,所以不确定它是否是编译器/平台的东西,但是当我尝
我正在尝试从eeprom重构一个32位浮点值.

eeprom存储器(0-4)中的4个字节为:B4 A2 91 4D

并且PC(VS Studio)正确地重建它为3.054199 * 10 ^ 8(我知道浮点值应该在那里)

现在我将这个eeprom从8位Arduino中读取,所以不确定它是否是编译器/平台的东西,但是当我尝试将4个字节读入32位双字,然后将其强制转换为浮点数时,我得到的价值甚至不是很接近.

假设无法使用标准ansi-c编译器自动完成转换,那么如何手动将4个字节解析为浮点数?

解决方法

最安全的方法,也是由于编译器优化也和其他任何一样快,是使用memcpy:

uint32_t dword = 0x4D91A2B4;
float f;
memcpy(&f,&dw,4);

演示:http://ideone.com/riDfFw

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读