大战熟女丰满人妻av-荡女精品导航-岛国aaaa级午夜福利片-岛国av动作片在线观看-岛国av无码免费无禁网站-岛国大片激情做爰视频

專注Java教育14年 全國咨詢/投訴熱線:400-8080-105
動力節點LOGO圖
始于2009,口口相傳的Java黃埔軍校
首頁 學習攻略 Java學習 Java浮點型比較的正確方法

Java浮點型比較的正確方法

更新時間:2020-09-11 16:36:52 來源:動力節點 瀏覽4303次

1.浮點數表示

在計算機系統理論中,浮點數采用IEEE 754標準表示,編碼方式是符號+階碼+尾數,如圖:

Java浮點型比較的正確方法

比如f·oat類型占用32位,單精度浮點表示法:

符號位(sign)占用1位,用來表示正負數,0表示正數,1表示負數

指數位(exponent)占用8位,用來表示指數,實際要加上偏移量

小數位(fraction)占用23位,用來表示小數,不足位數補0

從這里可以看出,指數位決定了大小范圍,小數位決定了計算精度。當十進制數值轉換為二進制科學表達式后,得到的尾數位數是有可能很長甚至是無限長。所以當使用浮點格式來存儲數字的時候,實際存儲的尾數是被截取或執行舍入后的近似值。這就解釋了浮點數計算不準確的問題,因為近似值和原值是有差異的。

2.比較浮點數的方式

讓我們來驗證一下比較浮點數的幾種方式。

1.==操作符

比較兩個浮點數,一個從零開始加11次0.1,另一個用0.1乘以11計算。然后用==比較大小。

????private?void?compareByOperator()?{
????????float?f1?=?0.0f;
????????for?(int?i?=?0;?i?<?11;?i++)?{
????????????f1?+=?0.1f;
????????}

????????float?f2?=?0.1f?*?11;

????????System.out.println("f1?=?"?+?f1);
????????System.out.println("f2?=?"?+?f2);

????????if?(f1?==?f2)?{
????????????System.out.println("f1?and?f2?are?equal?using?operator?==");
????????}?else?{
????????????System.out.println("f1?and?f2?are?not?equal?using?operator?==");
????????}
????}


運行輸出:

f1?=?1.1000001
f2?=?1.1
f1?and?f2?are?not?equal

可以看到,兩個浮點數不相等,所以通過==來比較浮點數是不可靠的。

2.誤差范圍

指定一個誤差范圍,兩個浮點數的差值在范圍之內,則認為是相等的。使用Math.abs()計算差值,然后和閾值比較。

???private?void?compareByThreshold()?{
????????final?float?THRESHOLD?=?0.000001;
????????float?f1?=?0.0f;
????????for?(int?i?=?0;?i?<?11;?i++)?{
????????????f1?+=?0.1f;
????????}

????????float?f2?=?0.1f?*?11;

????????System.out.println("f1?=?"?+?f1);
????????System.out.println("f2?=?"?+?f2);

????????if?(Math.abs(f1?-?f2)?<?THRESHOLD)?{
????????????System.out.println("f1?and?f2?are?equal?using?threshold");
????????}?else?{
????????????System.out.println("f1?and?f2?are?not?equal?using?threshold");
????????}
????}


運行輸出:

f1?=?1.1000001
f2?=?1.1
f1?and?f2?are?equal?using?threshold

3.使用BigDecima·

BigDecima·是不可變的,能夠精確地表示十進制數字。需要注意的是,創建BigDecima·對象時,要使用參數為String的構造方法,不要使用構造參數為doub·e的,如果非要使用doub·e創建,一定要用va·ueOf靜態方法,防止丟失精度。然后調用compareTo方法比較即可。

????private?void?compareByBigDecimal()?{
????????BigDecimal?f1?=?new?BigDecimal("0.0");
????????BigDecimal?pointOne?=?new?BigDecimal("0.1");
????????for?(int?i?=?0;?i?<?11;?i++)?{
????????????f1?=?f1.add(pointOne);
????????}

????????BigDecimal?f2?=?new?BigDecimal("0.1");
????????BigDecimal?eleven?=?new?BigDecimal("11");
????????f2?=?f2.multiply(eleven);

????????System.out.println("f1?=?"?+?f1);
????????System.out.println("f2?=?"?+?f2);

????????if?(f1.compareTo(f2)?==?0)?{
????????????System.out.println("f1?and?f2?are?equal?using?BigDecimal");
????????}?else?{
????????????System.out.println("f1?and?f2?are?not?equal?using?BigDecimal");
????????}
????}

運行輸出:

f1?=?1.1
f2?=?1.1
f1?and?f2?are?equal?using?BigDecimal

3.結論

使用==比較浮點數不準確,可以采用誤差范圍近似相等,或者BigDecima·計算比較。

Java浮點型比較的正確方法

以上就是動力節點java培訓機構的小編針對“Java浮點型比較的正確方法”的內容進行的回答,希望對大家有所幫助,如有疑問,請在線咨詢,有專業老師隨時為你服務。

提交申請后,顧問老師會電話與您溝通安排學習

免費課程推薦 >>
技術文檔推薦 >>
主站蜘蛛池模板: 国产精品成人va | 在线欧美国产 | 精品久久久中文字幕 | 欧美精品色视频 | 欧美日韩中文字幕久久伊人 | 性做久久久久久免费观看 | 麻豆一区二区三区四区 | 日本中文字幕二区三区 | 国产中文字幕视频 | 欧美成人七十二式性视频教程 | 久久99国产精品亚洲 | 欧美第一精品 | 亚洲国产图片 | 国产国产成人精品久久 | 网红福利在线 | 亚洲精品第五页中文字幕 | 性ao爱大片 | 四虎国产成人亚洲精品 | 久久久久亚洲 | 2020亚洲欧美日韩在线观看 | 福利院肉动漫视频在线观看 | 99精品大学生啪啪自拍 | 曰本毛片| 久久精品99精品免费观看 | 亚洲精品123区在线观看 | 欧美精品99久久久久久人 | 成人毛片高清视频观看 | 欧美xxxxx性另类 | 欧美一级α片毛片免费观看 | 亚洲精品亚洲人成在线播放 | 亚洲国产精品乱码一区二区三区 | 鲁丝一区二区三区不属 | 久久综合在线 | 一级毛片在线观看视频 | 狠狠色香婷婷久久亚洲精品 | 麻豆亚洲一区 | 亚洲午夜久久影院 | 中国国产成人精品久久 | 在线观看国产一区二三区 | 一级片a级片 | 亚洲精品高清国产一久久 |