作者chuegou (chuegou)
看板C_and_CPP
標題Re: [問題]Float的資料用Char的Buffer傳輸
時間Thu Feb 25 22:26:20 2016
※ 引述《MasterChang (我愛ASM)》之銘言:
: : → x000032001: 那就直接把float拆成4bytes 不是最快 02/25 16:35
: : 推 qscgy4: 樓上不懂可不可以不要出來嘴? 02/25 16:49
: : → qscgy4: 1.假設他的接收端浮點數不是4byte,你要怎麼處理? 02/25 16:51
: : → qscgy4: 2.我說的方法可以在在不同變數大小輕易轉換,不用任何lib 02/25 16:52
: : → qscgy4: 3.不用任何lib的狀況下,我是不會拆浮點數啦 02/25 16:55
: : → qscgy4: 可以教一下嗎? 02/25 16:55
: float 4 bytes, double 8 bytes 這個應該沒問題吧?
: 有疑問其實用sizeof()確認一下就好。
: #pragma pack(push)
: #pragma pack(1)
: typedef union{
: float f;
: char b[4];
: }Fto4Bytes_t;
: #pragma pack(pop)
: 這個不需要library....轉個念而已。
union是最直覺的方式
我剛開始也是用union
後來發覺前輩都用指標(雖然我不知道那個比較好)
先確認一下大小
float 4byte
char 1byte
------------------------
float f;
char *cptr = (char*)&f;
// 宣告char(1byte)指標cptr指向浮點數f
// 用*(cptr+0) , *(cptr+1), *(cptr+2), *(cptr+3)來對f進行操作
// 或用 cptr[0] , cptr[1], cptr[2], cptr[3]來對f進行操作
------------------------
這裡要注意的是有些MCU的高位低位順序會不一樣
傳到另一邊重組起來的時候要注意
因為我感覺原PO是在兩個不同平台上作業
先提醒一下
--
※ 發信站: 批踢踢實業坊(ptt.cc), 來自: 36.230.110.157
※ 文章網址: https://www.ptt.cc/bbs/C_and_CPP/M.1456410384.A.3C3.html
→ ronin728: 以前聽說過byte order的問題,在這會出現嗎? 有點怕怕的 02/26 03:55
推 ronin728: 原po我對不起你,剛剛文章我沒看到最後一段,感謝說明 02/26 03:57
→ shadow0326: 確認一下轉出和轉入的機器是什麼endian就好 02/26 11:24
原來是叫做這兩個名稱
我一直不知道這個現象要怎麼說明XD
感謝補充
※ 編輯: chuegou (36.230.110.157), 02/26/2016 15:44:28
→ bdvstg: 大印地安 小印地安 不同機器傳還蠻常遇到的 轉一下就好 02/26 19:10
→ LPH66: 不是印地安, 是大頭小頭...這詞是出自《格列佛遊記》的 02/26 22:20
→ LPH66: 就那個要從蛋的大頭敲開還是小頭敲開的那個故事 02/26 22:21
→ LPH66: 所以那是從 end 衍生成的 endian 這詞, 跟 Indian 完全不同 02/26 22:22
→ chuegou: 居然還有語源考證!給樓上推 02/26 22:25
推 bdvstg: 喔喔喔~~!! 原來還有這典故 推!!! 樓上說好的推呢? 02/26 22:51
推
別逼我!!!
※ 編輯: chuegou (36.230.110.157), 02/26/2016 22:55:11
→ bdvstg: XDDDD 02/27 01:26
推 Caesar08: 推LPH66 02/27 11:52
→ fgkor123: 蠻有趣的 02/28 09:02
推 lc85301: 推語源考證XDD 02/28 13:45
→ linotwo: 在 buffer 塞一個 flag 表示 endianness 就好 03/08 01:31