java float直接轉double會出現偏差

經過debug發現,float 直接轉換double會出現偏差。數據類型須要經過String轉一道java

 

 public static void main(String[] agrs){
        double a=2.8d;
        float a1=2.8f;
        double a2=a1;
        System.out.println("a1==a2:"+(a1==a2));
        System.out.println("a==a2:"+(a==a2));
        System.out.println(a1);
        System.out.println(a2);
    }

結果spa

a1==a2:true
a==a2:false
2.8
2.799999952316284

如例子所示,2.8轉爲double 成了2.799999952316284。,失去精度。debug

 

public static void main(String[] agrs){
        double a=2.8d;
        float a1=2.8f;
        double a2=Double.valueOf(String.valueOf(a1));
        System.out.println("a1==a2:"+(a1==a2));//java自動將a1轉爲double
        System.out.println("a==a2:"+(a==a2));
        System.out.println(a1);
        System.out.println(a2);
    }

結果code

a1==a2:false  
a==a2:true
2.8
2.8
相關文章
相關標籤/搜索