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

標(biāo)題: 關(guān)于C語言中float、double類型的內(nèi)存轉(zhuǎn)換 [打印本頁]

作者: toomark    時(shí)間: 2020-4-8 10:19
標(biāo)題: 關(guān)于C語言中float、double類型的內(nèi)存轉(zhuǎn)換
     C51 平臺(tái)上存在數(shù)據(jù)類型限制——double數(shù)據(jù)類型與float數(shù)據(jù)類型皆為32bites,使得double數(shù)據(jù)類型等同于float數(shù)據(jù)類型。

     當(dāng)C51在與其它平臺(tái)做數(shù)據(jù)通信時(shí),可能被要求提供64bites的double數(shù)據(jù),但它無法用數(shù)據(jù)類型強(qiáng)轉(zhuǎn)實(shí)現(xiàn)。因此,專門寫了float轉(zhuǎn)double存儲(chǔ)的函數(shù)。

     有關(guān)float、double類型在內(nèi)存中的具體存儲(chǔ)方式,可閱讀相關(guān)博文https://blog.csdn.net/slience_j/article/details/51965009
     實(shí)現(xiàn)float存儲(chǔ)轉(zhuǎn)double類型存儲(chǔ)的具體函數(shù)如下:
  1. #pragma pack(1)
  2. struct DOUBLE_MEM
  3. {
  4.         char data0;
  5.         char data1;
  6.         char data2;
  7.         char data3;
  8.         char data4;
  9.         char data5;
  10.         char data6;
  11.         char data7;
  12. };
  13. #pragma pack()

  14. void float_to_double(float f, struct DOUBLE_MEM *pStrBob)
  15. {
  16.         short index;                        // 指數(shù)
  17.         long *pdata = (long *)&f;        // 指針指向需轉(zhuǎn)換float數(shù)據(jù)

  18.         // 獲取float變量8位有效指數(shù)信息
  19.         index = (*pdata >>23)&0x00ff;        
  20.         // 將8位指數(shù)轉(zhuǎn)換為11位指數(shù)
  21.         if(index & 0x0080)                // 指數(shù)為正(bit7表示正負(fù),bit0~6為大小)
  22.         {
  23.                 index &= 0x007f;        // bit7~15置0
  24.                 index |= 0x0400;        // bit10  置1
  25.         }else
  26.         {
  27.                 index |= 0xff80;        // bit 7~15置1
  28.                 index &= 0x03ff;        // bit10~15置0
  29.         }
  30.         
  31.         // 裝載index指數(shù)信息
  32.         pStrBob->data0 = (index>>4)&0x7f; // 將index的高7位(bit4~10位)數(shù)據(jù)放在低7位存儲(chǔ)
  33.         pStrBob->data1 = (index &0xf)<<4; // 將index的低4位(bit0~3位)數(shù)據(jù)放在高4位存儲(chǔ)

  34.         // 裝載符號(hào)信息(存放在最高位)
  35.         if(*pdata & 0x80000000)
  36.         {
  37.                 pStrBob->data0 |= 0x80;
  38.         }
  39.         else
  40.         {
  41.                 pStrBob->data0 &= 0x7f;
  42.         }

  43.         // 裝載尾數(shù)位(bit0~bit22共23位有效數(shù)據(jù))
  44.         pStrBob->data1 |= (*pdata >>19)&0x0f;        // 將bit19~22  放至data1的低4位
  45.         pStrBob->data2 = (*pdata >>11)&0xff;        // 將bit11~18  放至data2
  46.         pStrBob->data3 = (*pdata >>3)&0xff;        // 將bit3~bit10放至data3
  47.         pStrBob->data4 = (*pdata &0x7)<<5;        // 將bit0~bit2 放至data4的高3位
  48.         pStrBob->data4 &= 0xe0;                        // data4的低5位清零
  49.         pStrBob->data5 = 0x0;
  50.         pStrBob->data6 = 0x0;
  51.         pStrBob->data7 = 0x0;
  52. }
復(fù)制代碼









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