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

標題: 單片機存儲浮點數后再次讀取發現變小了,求解決辦法 [打印本頁]

作者: mcuee    時間: 2020-3-17 11:21
標題: 單片機存儲浮點數后再次讀取發現變小了,求解決辦法
如題,現在單片機需要保存一個浮點數(float)到eeprom,比如保存的數字是1.0010,保存后再讀取發現變成了1.0009 ,雖說對運算結果影響不大,但還是想前后保持一致,請問有什么辦法嗎?謝謝!

作者: Y_G_G    時間: 2020-3-17 13:45
一個8位的單片機是可以不用浮點數據的
1.0010是可以=10010的,高低兩個字節就可以保存了
1.0010卻要用四個字節來保存,我不知道C51的標準,但如果占用內存過多的話,就會把多出來 的部分去掉不了,這就產生誤差了
如果能用整型數據就盡量用整型的,沒有說是一定要用浮點型不可的
作者: SHXL_1    時間: 2020-3-17 15:40
采用union,里面包含一個float型數據,4個byte組成的struct數據。
作者: eastjack    時間: 2020-3-17 17:29
用四舍五入法處理。ieee浮點表示有精度誤差。
作者: 天地一微塵    時間: 2020-3-17 22:23
可以考慮保存成int類型,取用的時候運算一下就行了。
作者: 王天星    時間: 2020-3-18 13:01
我遇到過這種情況,做暴力的做法就是保留精度轉換成int




歡迎光臨 (http://www.raoushi.com/bbs/) Powered by Discuz! X3.1