Float xx = 2.0f; Float yy = 1.8f; Float tt = xx - yy; System.out.println("tttttt-----" + tt);
果然輸出結(jié)果是: tttttt-----0.20000005
再測(cè)試了幾個(gè)float類型的減法,除了*.0這樣的相減沒有異議之外,都存在這個(gè)問題,就是說float在相減的時(shí)候精度丟失了。后來在網(wǎng)上找到一段解決這個(gè)問題的辦法,記在這里:
BigDecimal b1 = new BigDecimal(Float.toString(xx)); BigDecimal b2 = new BigDecimal(Float.toString(yy)); float ss = b1.subtract(b2).floatValue(); System.out.println("ssss----" + ss);
發(fā)表評(píng)論