• <ins id="pjuwb"></ins>
    <blockquote id="pjuwb"><pre id="pjuwb"></pre></blockquote>
    <noscript id="pjuwb"></noscript>
          <sup id="pjuwb"><pre id="pjuwb"></pre></sup>
            <dd id="pjuwb"></dd>
            <abbr id="pjuwb"></abbr>

            浮點數(shù)簡介

            內(nèi)存中的儲存形式(IEEE-745)

            Address 3        2        1        0 
            Content SEEEEEEE EBBBBBBB BBBBBBBB BBBBBBBB

            其中的字母分別代表:

            • S(Significand):1 - 正負(fù)號(-1)^S
            • E(Exponent):8 - 指數(shù)部分
            • B(Base):23 - 底數(shù)部分

            這樣, 整個浮點數(shù)表示起來就是:

            (-1)^S \times 1.BBBBBBBBBBBBBBBBBBBBBBB \times 2 ^{EEEEEEEE - 01111111}

            N進(jìn)制的小數(shù)

            看到10進(jìn)制的小數(shù), 小數(shù)點是用來分隔指數(shù)正負(fù)位的:

            123.456
            = 1 \times 10^2 + 2 \times 10^1 + 3 \times 10^0 + 4 \times 10^{-1} + 5 \times 10^{-2} + 6 \times 10^{-3}

            推廣到N進(jìn)制, 形式是完全相同的, 這里用二進(jìn)制做一個例子:

            (101.0101)_2
            = 2^2 + 2^0 + 2^{-2} + 2^{-4}
            = 4+1+{1 \over 4}+{1 \over 16}
            = 5.3125

            構(gòu)造一個浮點數(shù)

            以12.625為例子. 首先我們推算一下它的二進(jìn)制形式是什么. 如我們所知, 整數(shù)部分和小數(shù)部分的位置是恒定不變的, 因為它們是否小于1這個性質(zhì), 無論在什么進(jìn)制之下都不會改變. 首先算整數(shù)部分:

            12 \div 2 = 6 \cdots 0
            6 \div 2 = 3 \cdots 0
            3 \div 2 = 1 \cdots 1
            1 \div 2 = 0 \cdots 1
            \therefore \ (12)_10 = (1100)_2

            小數(shù)部分(不知道是否注意到, 小數(shù)部分只有是2^n的和才有可能被表示成不循環(huán)小數(shù). 諸如0.7, 0.3都是二進(jìn)制的無限循環(huán)小數(shù)):

            0.625 \times 2 = 1 + 0.25
            0.25 \times 2 = 0 + 0.5
            0.5 \times 2 = 1
            \therefore \ (0.625)_{10} = (0.101)_2

            這樣, 我們得到了一個二進(jìn)位的小數(shù)1100.101, 并且化成IEEE-745標(biāo)準(zhǔn)形式:

            1100.101 = 1.100101 \times 2^{00000011 + 01111111 - 01111111}

            Address 3        2        1        0 
            Content SEEEEEEE EBBBBBBB BBBBBBBB BBBBBBBB
            Value   01000001 01001010 00000000 00000000
            Hex           41       4A       00       00

            現(xiàn)在我們得到了一個整數(shù)0x414A0000, 把它輸出出來看看是多少:

            $ cat test.c 
            #include <stdio.h>
            int main()
            {
               union {
                  unsigned long u;
                  float f;
               } u;
               u.u = 0x414a0000;
               printf("%f\n", u.f);
               return 0;
            }

            $ ./test
            12.625000

            posted on 2015-01-02 14:38 Shihira 閱讀(2064) 評論(0)  編輯 收藏 引用


            只有注冊用戶登錄后才能發(fā)表評論。
            網(wǎng)站導(dǎo)航: 博客園   IT新聞   BlogJava   博問   Chat2DB   管理


            導(dǎo)航

            統(tǒng)計

            公告

            留言簿(2)

            隨筆分類

            搜索

            最新隨筆

            最新評論

            閱讀排行榜

            評論排行榜

            久久99精品久久久久久hb无码| 久久婷婷五月综合97色直播| 久久r热这里有精品视频| 亚洲国产天堂久久综合网站| 久久国产精品偷99| 国产69精品久久久久观看软件 | 久久露脸国产精品| 亚洲国产日韩欧美久久| 久久精品人人槡人妻人人玩AV| 亚洲国产精久久久久久久| 中文字幕精品无码久久久久久3D日动漫 | 久久99国产综合精品| 国产成人无码精品久久久久免费| 久久久国产99久久国产一| 精品国产一区二区三区久久| 国产精品久久久久久久人人看| 久久精品国产半推半就| 无码伊人66久久大杳蕉网站谷歌 | 久久WWW免费人成一看片| 青青热久久综合网伊人| 精品伊人久久大线蕉色首页| 久久久久无码精品国产app| 久久99精品久久久久久久久久 | 久久99热只有频精品8| 亚洲国产成人久久综合野外| 伊人久久综在合线亚洲2019| 久久ZYZ资源站无码中文动漫| 久久只这里是精品66| 久久久久国产精品三级网 | 久久丝袜精品中文字幕| 久久国产精品国产自线拍免费| 久久久国产乱子伦精品作者| 亚洲中文字幕久久精品无码APP | 久久青草国产精品一区| 99久久国产热无码精品免费| 久久久久亚洲av无码专区喷水 | 久久久久人妻精品一区三寸蜜桃| 国产精品美女久久久| 99久久免费国产精品热| 久久青青草原精品影院| 国产 亚洲 欧美 另类 久久|