float与double的位分配

来源:互联网 发布:java邮箱发送 编辑:程序博客网 时间:2024/05/05 00:42


 
摘自网络:http://zhidao.baidu.com/question/344295417.html 

单精度浮点数在机内占4个字节,用32位二进制描述。 
双精度浮点数在机内占8个字节,用64位二进制描述。 

浮点数在机内用指数型式表示,分解为:数符,尾数,指数符,指数四部分。 
数符占1位二进制,表示数的正负。 
指数符占1位二进制,表示指数的正负。 
尾数表示浮点数有效数字,0.xxxxxxx,但不存开头的0和点 
指数存指数的有效数字。 

指数占多少位,尾数占多少位,由计算机系统决定。 
可能是数符加尾数占24位,指数符加指数占8位 -- float. 
数符加尾数占48位,指数符加指数占16位 -- double. 

知道了这四部分的占位,按二进制估计大小范围,再换算为十进制,就是你想知道的数值范围。 

对编程人员来说,double 和 float 的区别是double精度高,有效数字16位,float精度7位。但double消耗内存是float的两倍,double的运算速度比float慢得多,java语言中数学函数名称double 和 float不同,不要写错,能用单精度时不要用双精度(以省内存,加快运算速度) 

补充: 
(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"也可以不写
0 0
原创粉丝点击