stone2083

          IEEE 754 浮點存儲小記

          IEEE 754:

          https://zh.wikipedia.org/wiki/IEEE_754


          FLOAT:

          31  30         22       15          7          0

          +---+----------+---------+----------+----------+

          |   |          |                               |

          +---+----------+---------+----------+----------+

          + S +     E    +               M               +


          EXAMPLE(5.5):

          =============================

          int main() {

              float a = 5.5;

              int *p = &a;

              printf("%d\n", *p);

              printf("%X\n", *p);

          }


          gcc -o main main.c; ./main

          十進制:    1085276160

          十六進制:  40B00000

          =============================



          十進制 = 二進制 = 二進制指數(shù)形式

          5.5    = 101.1  = 1.011 * 2^2


          ==> S=0 E=2 M = 11


          31  30         22       15          7          0

          +---+----------+---------+----------+----------+

          | 0 | 10000001 | 0110000 | 00000000 | 00000000 |

          +---+----------+---------+----------+----------+

          + S +     E    +               M               +


          轉(zhuǎn)換成INT:

          二進制:    01000000101100000000000000000000

          十進制:    1085276160

          十六進制:  40B00000



          EXAMPLE(5.1):

          ===========================================

          int main() {

              float a = 5.1;

              int *p = &a;

              printf("Float:\t%f\n", a);

              printf("十進制:\t%d\n", *p);

              printf("十六進制:\t%X\n", *p);

          }


          gcc -o main main.c; ./main

          Float:    5.100000

          十進制:    1084437299

          十六進制:  40A33333

          ===========================================


          存儲形式:0b01000000101000110011001100110011

          有效尾數(shù):01000110011001100110011

          表達方式:1.01000110011001100110011 * 2^2 ==> 101.000110011001100110011


          101 ==> 5

          0.000110011001100110011 ==> 2^-4 + 2^-5 + 2^-8 + 2^-9 + 2^-12 + 2^-13 + 2^-16 + 2^-17 + 2^-20 + 2^-21


          實際表達:      5.09999990463256836

          保留6位小數(shù):   5.100000

          posted on 2017-10-12 11:23 stone2083 閱讀(662) 評論(0)  編輯  收藏


          只有注冊用戶登錄后才能發(fā)表評論。


          網(wǎng)站導航:
           
          主站蜘蛛池模板: 遂平县| 肃宁县| 遂川县| 印江| 四会市| 青川县| 通榆县| 日喀则市| 峨眉山市| 晋州市| 嘉荫县| 广汉市| 汽车| 兴隆县| 苏尼特左旗| 渝中区| 彩票| 亚东县| 澳门| 浪卡子县| 宜兴市| 林甸县| 土默特右旗| 介休市| 托里县| 靖边县| 象州县| 达拉特旗| 鹿泉市| 嵩明县| 化德县| 保山市| 张家港市| 苏尼特右旗| 深圳市| 石景山区| 龙陵县| 亚东县| 乌鲁木齐县| 怀远县| 驻马店市|