找回密码
 立即注册

QQ登录

只需一步,快速开始

搜索
查看: 1746|回复: 5
打印 上一主题 下一主题
收起左侧

单片机存储浮点数后再次读取发现变小了,求解决办法

[复制链接]
跳转到指定楼层
楼主
ID:491246 发表于 2020-3-17 11:21 | 只看该作者 回帖奖励 |倒序浏览 |阅读模式
如题,现在单片机需要保存一个浮点数(float)到eeprom,比如保存的数字是1.0010,保存后再读取发现变成了1.0009 ,虽说对运算结果影响不大,但还是想前后保持一致,请问有什么办法吗?谢谢!
分享到:  QQ好友和群QQ好友和群 QQ空间QQ空间 腾讯微博腾讯微博 腾讯朋友腾讯朋友
收藏收藏 分享淘帖 顶 踩
回复

使用道具 举报

沙发
ID:401564 发表于 2020-3-17 13:45 | 只看该作者
一个8位的单片机是可以不用浮点数据的
1.0010是可以=10010的,高低两个字节就可以保存了
1.0010却要用四个字节来保存,我不知道C51的标准,但如果占用内存过多的话,就会把多出来 的部分去掉不了,这就产生误差了
如果能用整型数据就尽量用整型的,没有说是一定要用浮点型不可的
回复

使用道具 举报

板凳
ID:709207 发表于 2020-3-17 15:40 | 只看该作者
采用union,里面包含一个float型数据,4个byte组成的struct数据。
回复

使用道具 举报

地板
ID:699855 发表于 2020-3-17 17:29 | 只看该作者
用四舍五入法处理。ieee浮点表示有精度误差。
回复

使用道具 举报

5#
ID:709787 发表于 2020-3-17 22:23 来自手机 | 只看该作者
可以考虑保存成int类型,取用的时候运算一下就行了。
回复

使用道具 举报

6#
ID:531524 发表于 2020-3-18 13:01 | 只看该作者
我遇到过这种情况,做暴力的做法就是保留精度转换成int
回复

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

手机版|小黑屋|51黑电子论坛 |51黑电子论坛6群 QQ 管理员QQ:125739409;技术交流QQ群281945664

Powered by 单片机教程网

快速回复 返回顶部 返回列表