[求指教] Golang 浮点数有个疑问 - V2EX
请不要在回答技术问题时复制粘贴 AI 生成的内容
tqz

[求指教] Golang 浮点数有个疑问

  •  
  •   tqz Jul 2, 2020 2496 views
    This topic created in 2139 days ago, the information mentioned may be changed or developed.

    问题描述

    float32 的精度是小数点后面 6 位,这个我没说错吧。。(万一我记错了请批我)

    那么我的理解就是把 float3210000018 表示成科学计数法就应该是:1.000002e+07 (四舍五入了)

    但是 go 输出的结果是:1.0000018e+07,代码如下

    package main import "fmt" var num float32 = 10000018 // 8 位 <==> 1.0000018 * 10^7 func main() { fmt.Println("num: ", num) // 1.0000018e+07 ??小数点后面怎么有 7 位 } 

    小数点后面怎么有 7 位?和我预想的不一样。。

    并且

    并且我把 10000018 加个 7 得到 100000187 然后再试一次,又变成小数点后 8 位了,代码如下:

    package main import "fmt" //var myfloat float32 = 10000018 // 8 位 <==> 1.0000018 * 10^7 var myfloat float32 = 100000182 // 9 位 <==> 1.00000182 * 10^8 var ans float32 = 100000187 // 9 位 <==> 1.00000187 * 10^8 func main() { fmt.Println("myfloat: ", myfloat) // 1.00000184e+08 fmt.Println(myfloat == myfloat + 1) // true fmt.Println("myfloat: ", myfloat+5) // 1.0000019e+08 fmt.Println(ans == myfloat+5) // false } 

    1.00000184e+08 这个数有 8 个小数,我不太懂了。。

    关于 IEEE-754 的介绍我也看了,还是有疑惑。

    求大神指教。

    Supplement 1    Jul 2, 2020

    结贴

    不好意思,是我愚昧了,脑子没转过来。

    我现在懂了,以后一定好好阅读文献,不马虎了。

    InkStone
        1
    InkStone  
       Jul 2, 2020
    你是怎么做到看了 IEEE754 还能把 float 理解成”小数点后保留六位小数“的?

    float 按二进制取整,输出成十进制有几位小数纯看运气和输出格式
    reus
        2
    reus  
       Jul 2, 2020
    知道浮点数为啥叫“浮点”数吗?
    就是小数点位置是不固定的,所以你一开始就错了
    1010543618
        3
    1010543618  
       Jul 2, 2020
    计算机组成原理忘得差不多了
    随便找了个介绍 https://www.runoob.com/w3cnote/32-float-storage.html,貌似规格化之后能有 24 bit (16777216) 的精度
    ipwx
        4
    ipwx  
       Jul 2, 2020
    1.00000184e+08 这个数有 8 个小数:

    楼主你真的看了浮点数标准么?
    ----

    首先 3L 给了你一个资料了,32 位浮点数的底数最多能有 24 bit,也就是最多八位( 2**24 = 16777216 )。剩下 8 位是指数,所以指数最多是 e128 这个量级。和小数点以后到底多少位根本没有关系,看的是指数和底数的有效数位。
    About     Help     Advertise     Blog     API     FAQ     Solana     1019 Online   Highest 6679       Select Language
    创意工作者们的社区
    World is powered by solitude
    VERSION: 3.9.8.5 45ms UTC 22:32 PVG 06:32 LAX 15:32 JFK 18:32
    Do have faith in what you're doing.
    ubao msn snddm index pchome yahoo rakuten mypaper meadowduck bidyahoo youbao zxmzxm asda bnvcg cvbfg dfscv mmhjk xxddc yybgb zznbn ccubao uaitu acv GXCV ET GDG YH FG BCVB FJFH CBRE CBC GDG ET54 WRWR RWER WREW WRWER RWER SDG EW SF DSFSF fbbs ubao fhd dfg ewr dg df ewwr ewwr et ruyut utut dfg fgd gdfgt etg dfgt dfgd ert4 gd fgg wr 235 wer3 we vsdf sdf gdf ert xcv sdf rwer hfd dfg cvb rwf afb dfh jgh bmn lgh rty gfds cxv xcv xcs vdas fdf fgd cv sdf tert sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf sdf shasha9178 shasha9178 shasha9178 shasha9178 shasha9178 liflif2 liflif2 liflif2 liflif2 liflif2 liblib3 liblib3 liblib3 liblib3 liblib3 zhazha444 zhazha444 zhazha444 zhazha444 zhazha444 dende5 dende denden denden2 denden21 fenfen9 fenf619 fen619 fenfe9 fe619 sdf sdf sdf sdf sdf zhazh90 zhazh0 zhaa50 zha90 zh590 zho zhoz zhozh zhozho zhozho2 lislis lls95 lili95 lils5 liss9 sdf0ty987 sdft876 sdft9876 sdf09876 sd0t9876 sdf0ty98 sdf0976 sdf0ty986 sdf0ty96 sdf0t76 sdf0876 df0ty98 sf0t876 sd0ty76 sdy76 sdf76 sdf0t76 sdf0ty9 sdf0ty98 sdf0ty987 sdf0ty98 sdf6676 sdf876 sd876 sd876 sdf6 sdf6 sdf9876 sdf0t sdf06 sdf0ty9776 sdf0ty9776 sdf0ty76 sdf8876 sdf0t sd6 sdf06 s688876 sd688 sdf86