日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 编程资源 > 编程问答 >内容正文

编程问答

关于数据精度的一些事

發布時間:2024/1/17 编程问答 50 豆豆
生活随笔 收集整理的這篇文章主要介紹了 关于数据精度的一些事 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.
  • 基礎數據類型

  • ????? 大家都知道,Java中表示小數的基本類型有float, double, 如果你想計算0.3 - 0.1,很遺憾答案并不是0.2,有些人會說,用BigDecimal就可以啦,float和double就是會存在精度問題的。本文想探究一下,為什么, 為什么會無法得到正確答案。

    先講一些題外話,十進制和二進制。

    計算機的世界是二進制,0和1組成,

    二進制轉十進制不在贅述,高中就學過的;

    十進制轉二進制,看下這個圖, 應該也比較清楚了:

    主要來看一下,十進制小數怎么轉化為二進制(如果是3.45這類的小數拆分為3 和0.45,3按照上面的轉換方式,0.45按照如下方式)。

    這里,底是2。舉例十進制0.1轉為二進制:

     結果:?? 0.0

    1. 0.1 * 2 = 0.2 整數0為二進制結果的第一位,即0.0;小數0.2作為源,繼續執行

    2. 0.2 * 2 = 0.4 整數0為二進制結果的第二位,即0.00;小數0.4作為源,繼續執行

    3. 0.4 * 2 = 0.8 整數0為二進制結果的第三位,即0.000;小數0.8作為源,繼續執行

    4. 0.8 * 2 = 1.6 整數1為二進制結果的第四位,即0.0001;小數0.6作為源,繼續執行

    5. 0.6 * 2 = 1.2 整數1為二進制結果的第四位,即0.00011;小數0.2作為源,繼續執行

    ......

    最后執行下去,發現0.1轉換為二進制為(0.00011001100110011...)2

    ?所以,十進制的0.1計算機無法精確表示。因此,0.3 - 0.1得到的就不是精確值了。不過如果你用0.5 - 0.125是可以得到0.375的,為什么呢?因為,2-1,2-2,2-3這些是可以精確表示的。

    ?

    ?

    轉載于:https://www.cnblogs.com/studentytj/p/9249778.html

    總結

    以上是生活随笔為你收集整理的关于数据精度的一些事的全部內容,希望文章能夠幫你解決所遇到的問題。

    如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。