JAVA中的float和double的区别

您所在的位置:网站首页 double类型02d表示多少 JAVA中的float和double的区别

JAVA中的float和double的区别

2023-10-03 00:25| 来源: 网络整理| 查看: 265

1.两个在定义时的区别

        1)float型 内存分配4个字节,占32位,范围从10^-38到10^38 和 -10^38到-10^-38         例float x=123.456f,y=2e20f; 注意float型定义的数据末尾必须有"f"或"F",为了和double区别           (2)double型 内存分配8个字节,范围从10^-308到10^308 和 -10^-308到-10^-308         例double x=1234567.98,y=8980.09d; 末尾可以有"d"也可以不写       

2. 特别需要注意的是两个浮点数的算术运算

    直接使用 +,-,*,%运算符的问题

    public class Test{         public static void main(String args[]){         System.out.println(0.05+0.01);         System.out.println(1.0-0.42);         System.out.println(4.015*100);         System.out.println(123.3/100);         }     }     结果:     0.060000000000000005     0.5800000000000001     401.49999999999994     1.2329999999999999

原因:

        首先得从计算机本身去讨论这个问题。我们知道,计算机并不能识别除了二进制数据以外的任何数据。无论我们使用何种编程语言,在何种编译环境下工作,都要先 把源程序翻译成二进制的机器码后才能被计算机识别。以上面提到的情况为例,我们源程序里的2.4是十进制的,计算机不能直接识别,要先编译成二进制。但问 题来了,2.4的二进制表示并非是精确的2.4,反而最为接近的二进制表示是2.3999999999999999。原因在于浮点数由两部分组成:指数和尾数,这点如果知道怎样进行浮点数的二进制与十进制转换,应该是不难理解的。如果在这个转换的过程中,浮点数参与了计算,那么转换的过程就会变得不可预 知,并且变得不可逆。我们有理由相信,就是在这个过程中,发生了精度的丢失。而至于为什么有些浮点计算会得到准确的结果,应该也是碰巧那个计算的二进制与 十进制之间能够准确转换。而当输出单个浮点型数据的时候,可以正确输出,如

double d = 2.4; System.out.println(d);

       输出的是2.4,而不是2.3999999999999999。也就是说,不进行浮点计算的时候,在十进制里浮点数能正确显示。这更印证了我以上的想法,即如果浮点数参与了计算,那么浮点数二进制与十进制间的转换过程就会变得不可预知,并且变得不可逆。

       事实上,浮点数并不适合用于精确计算,而适合进行科学计算。这里有一个小知识:既然float和double型用来表示带有小数点的数,那为什么我们不称 它们为“小数”或者“实数”,要叫浮点数呢?因为这些数都以科学计数法的形式存储。当一个数如50.534,转换成科学计数法的形式为5.053e1,它 的小数点移动到了一个新的位置(即浮动了)。可见,浮点数本来就是用于科学计算的,用来进行精确计算实在太不合适了。

解决方法:

简化bigdecimal计算的小工具类

在《Effective   Java》这本书中也提到这个原则,float和double只能用来做科学计算或者是工程计算,在商业计算中我们要用java.math.BigDecimal。使用BigDecimal并且一定要用String来够造。

如果我们要做一个加法运算,需要先将两个浮点数转为String,然后够造成BigDecimal,在其中一个上调用add方法,传入另一个作为参数,然后把运算的结果(BigDecimal)再转换为浮点数。你能够忍受这么烦琐的过程吗?网上提供的工具类Arith来简化操作。它提供以下静态方法,包括加减乘除和四舍五入:   

public   static   double   add(double   v1,double   v2)    public   static   double   sub(double   v1,double   v2)    public   static   double   mul(double   v1,double   v2)    public   static   double   div(double   v1,double   v2)    public   static   double   div(double   v1,double   v2,int   scale)    public   static   double   round(double   v,int   scale)   import java.math.BigDecimal;        /**    * 进行BigDecimal对象的加减乘除,四舍五入等运算的工具类    * @author ameyume    *    */   public class Arith {            /**        * 由于Java的简单类型不能够精确的对浮点数进行运算,这个工具类提供精        * 确的浮点数运算,包括加减乘除和四舍五入。        */         //默认除法运算精度         private static final int DEF_DIV_SCALE = 10;                     //这个类不能实例化         private Arith(){         }            /**         * 提供精确的加法运算。         * @param v1 被加数         * @param v2 加数         * @return 两个参数的和         */         public static double add(double v1,double v2){             BigDecimal b1 = new BigDecimal(Double.toString(v1));             BigDecimal b2 = new BigDecimal(Double.toString(v2));             return b1.add(b2).doubleValue();         }                 /**         * 提供精确的减法运算。         * @param v1 被减数         * @param v2 减数         * @return 两个参数的差         */         public static double sub(double v1,double v2){             BigDecimal b1 = new BigDecimal(Double.toString(v1));             BigDecimal b2 = new BigDecimal(Double.toString(v2));             return b1.subtract(b2).doubleValue();         }                 /**         * 提供精确的乘法运算。         * @param v1 被乘数         * @param v2 乘数         * @return 两个参数的积         */         public static double mul(double v1,double v2){             BigDecimal b1 = new BigDecimal(Double.toString(v1));             BigDecimal b2 = new BigDecimal(Double.toString(v2));             return b1.multiply(b2).doubleValue();         }            /**         * 提供(相对)精确的除法运算,当发生除不尽的情况时,精确到         * 小数点以后10位,以后的数字四舍五入。         * @param v1 被除数         * @param v2 除数         * @return 两个参数的商         */         public static double div(double v1,double v2){             return div(v1,v2,DEF_DIV_SCALE);         }            /**         * 提供(相对)精确的除法运算。当发生除不尽的情况时,由scale参数指         * 定精度,以后的数字四舍五入。         * @param v1 被除数         * @param v2 除数         * @param scale 表示表示需要精确到小数点以后几位。         * @return 两个参数的商         */         public static double div(double v1,double v2,int scale){             if(scale


【本文地址】


今日新闻


推荐新闻


    CopyRight 2018-2019 办公设备维修网 版权所有 豫ICP备15022753号-3