float、double傻傻搞不清楚(2015年10月16日)

来源:互联网 发布:qq飞车交易平台软件 编辑:程序博客网 时间:2024/05/03 10:42

一直不太清楚float、double取值范围、应用场景以及底层性能等等,开发当中随意用,没有去将就什么时候该用哪个就要一定用哪个。

一、java当中声明的小数都默认是double类型的,float fo = 2.25会提示强转为float,float fo = 20.5521f;才是正确的;

二、float是单精度类型,精度是6(-7)位有效数字,占用4个字节的存储空间;

       double是双精度类型,精度是15位有效数字,double占用8个字节的存储空间

public class test {public static void main(String[] args) throws IOException  {float fo = 1.0202028888f;System.out.println(fo);}}
上述打印出1.0202029,只保留6-7位,说是四舍五入截取后面的,但亲测并不是,有时7、8才进位。

public class test {public static void main(String[] args) throws IOException  {float fo = 1.0202f;System.out.println(fo);}}
打印出1.0202,不会自动补全的,double同上两点。

三、(摘取)记住java一定要用double,亘古不变,就算数值不大也要用double,float放在内存中其实是当作double来处理的,它不会比double更节约内存资源,对应的double虚拟机会直接以double形式来进行处理,快速而且精度高,用float,不但不会节约内存资源,虚拟机为了校验float的精度,会花费更多的系统资源。同样short,char,boolean,byte在内存中都是以int形式来处理的。

四、在《Effective Java》这本书中也提到这个原则: float和double只能用来做科学计算或者是工程计算; 在商业计算中我们要用java.math.BigDecimal。

待补全


0 0
原创粉丝点击