最近一个项目,需要在EEPROM中保存浮点数,于是想到浮点数占四个字节,直接移位,发现得到的char型是0,看来这个方法不可行。搜索论坛,高人提议用联合体来解决,联合体看似与结构体相似,其不同之处在于结构体中每个变量占用不同的内存,而联合体共用一段内存,这就给保存浮点数提供了极大的便利。
比如我要保存一个浮点数a,我定义一个联合体
union
{
float x;
uchar s[4];
}F32_Sep;
然后把a的值赋给F32_Sep.x,这样一来其实s[0]对应了浮点数的最高位,s[3]对应其最低位,因此,保存到EEPROM中只需将s[0]~s[3]即可。
转自:http://blog.sina.com.cn/s/blog_4a3946360100zp2j.html
EEPROM中浮点数的保存方法

本文介绍了一种在EEPROM中保存浮点数的有效方法。通过使用联合体,可以将浮点数转换为四个字节的char类型数组进行存储。此方法解决了直接移位保存浮点数的问题,并详细解释了如何实现这一过程。
435

被折叠的 条评论
为什么被折叠?



