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 (编辑:李大同) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |
推荐文章
站长推荐
热点阅读