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

一直不太清楚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。

待补全


  • 2
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值