欧美极品高清xxxxhd,国产日产欧美最新,无码AV国产东京热AV无码,国产精品人与动性XXX,国产传媒亚洲综合一区二区,四库影院永久国产精品,毛片免费免费高清视频,福利所导航夜趣136

 找回密碼
 立即注冊

QQ登錄

只需一步,快速開始

搜索
查看: 2368|回復: 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 單片機教程網

快速回復 返回頂部 返回列表