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
- float、double傻傻搞不清楚(2015年10月16日)
- 字符char、字节byte傻傻分不清(2015年10月13日)
- 傻傻分不清楚---运筹学
- [技术分享 - ISA 篇] FTP 主动? 被动? 傻傻搞不清楚…
- 《八位,十六位,傻傻分不清楚》
- session?用户?傻傻分不清楚
- Cookie、Session傻傻分不清楚
- ""和null,傻傻分不清楚
- 金属,塑料,傻傻分不清楚
- 对象,数组,傻傻分不清楚
- 2015年10月16日
- 2016年11月5日常委搞基随笔
- 【U3D日记-2016年10月28日】float转int 误差!
- 10月16日
- 16、Cocos2dx 3.0游戏开发找小三之Node:父节点、子节点、傻傻分不清楚
- 文科,理科,傻傻分不清楚……
- MVP, MVC, MVVM, 傻傻分不清楚~
- 排序?重叠数?傻傻分不清楚
- Linux图像处理高手―GIMP与ImageMagicK
- Android学习日志之一:Intent知识点及其应用
- 欢迎使用CSDN-markdown编辑器
- 【自动化测试工具】QTP/UFT入门
- sql server 动态排序
- float、double傻傻搞不清楚(2015年10月16日)
- 【开发环境】Vmware下安装Ubuntu12.04后续:vmware tools+中文输入法
- pomelo之application的创建于初始化
- 自定义u-boot启动logo的方法
- php你可能忽略的小姿势
- Android Bitmap和Canvas
- ANDROID开发之SQLite详解
- Spring、SpringMVC、Mybatis框架整合
- cronExpression表达式