亚洲激情专区-91九色丨porny丨老师-久久久久久久女国产乱让韩-国产精品午夜小视频观看

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

浮點數的存儲

發布時間:2020-07-14 20:51:59 來源:網絡 閱讀:799 作者:程紅玲OOO 欄目:編程語言

讀了陳皓老師的魔數一文,對浮點數的存儲有了比較清晰的理解

float的存儲是32位的,而double的存儲方式是64位

存儲格式如下圖
浮點數的存儲

以64位雙精度來說

S是符號位,0為正數,1為負數
E是指數部分,11位可以表示的范圍是0~2047,為了能表示負數,這11位表示的數范圍是-1023~1023

每個浮點數都可以表示為2^n < 浮點數 < 2^(n+1)的形式
這里的n+1023就是指數E,以3.14為例子,2^1 < 3.14 < 2^2,E=1024
52bit可以表示的數是0~2^52-1,即2^52個數,我們可以把2^n~2^(n+1)分成2^52等份,看浮點占了多少比例,以3.14為例子,(3.14-2)/(4-2)=0.57,則0.57*2^52=2567051787601182.72,四舍五入M=2567051787601183

所以3.14在計算機中的存儲為
0 10000000000 1001000111101011100001010001111010111000010100011111

浮點數的計算方式:
(-1)^S (1 + (M / 2^23)) (2 ^ E-127)
64位的就類似下面這個式子了
(-1)^S (1 + (M / 2^52)) (2 ^ E-1023)

(-1)^0 (1 + 0.57000000000000006217248937900877) (2 ^ 1) = 3.1400000000000001243449787580175
有一定的誤差

《完》

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

双鸭山市| 泸西县| 灌阳县| 威宁| 巴塘县| 灵丘县| 鹿泉市| 株洲县| 乌拉特中旗| 陵水| 永泰县| 八宿县| 深州市| 新宁县| 金乡县| 厦门市| 阜宁县| 保康县| 桐梓县| 衡水市| 门源| 桑植县| 尼木县| 万州区| 柯坪县| 北宁市| 化隆| 鹤山市| 公主岭市| 会昌县| 宁强县| 禹城市| 深圳市| 壶关县| 荥阳市| 罗定市| 买车| 高青县| 盱眙县| 策勒县| 阿城市|