黑马程序员技术交流社区

标题: double和float有啥区别? [打印本页]

作者: 小ㄟMò    时间: 2015-12-23 12:18
标题: double和float有啥区别?
除了double分配8个字节内存空间,float分配4个字节,还有其他什么区别吗?还有打印的时候,%f和%lf有什么不同?
作者: wangmiaosen    时间: 2015-12-23 13:52
没人回复啊,我也想知道
作者: lynn010    时间: 2015-12-23 20:00
DOUBLE双精度,FLOAT单精度,FLOAT有效数字好像是7位 DOUBLE是16位吧
作者: 穿礼服的猫    时间: 2015-12-23 20:35
不知道啊,只是来评论的,好好
作者: pn314754148    时间: 2015-12-23 22:25
%f 是float  %lf  是long float
作者: 海棠依旧2046    时间: 2015-12-23 22:52
double精确到后15位,float7位,书写形式上也有区别
作者: holmesconan    时间: 2015-12-24 09:47
两个精度不同.   用 float 只能保留7位 .  double  可以保留15位
作者: 小ㄟMò    时间: 2015-12-24 12:47
海棠依旧2046 发表于 2015-12-23 22:52
double精确到后15位,float7位,书写形式上也有区别

那为啥打印出来的都是6位小数
作者: hmpx_ljj    时间: 2015-12-24 14:25
double、float都是浮点型。double(双精度型)比float(单精度型)存的数据更准确些,占的空间也更大。double精度是float的两倍,所以需要更精确的计算常使用double。
作者: hmpx_ljj    时间: 2015-12-24 14:26
double、float都是浮点型。double(双精度型)比float(单精度型)存的数据更准确些,占的空间也更大。double精度是float的两倍,所以需要更精确的计算常使用double。

作者: qiu1993    时间: 2015-12-24 17:04
就用一张图来说明Float为单精度,内存中占4个字节,有效数位是7位(因为有正负,所以不是8位),double为双精度,占8个字节,有效数位是16位

QQ截图20151224164558.png (31.15 KB, 下载次数: 25)

QQ截图20151224164558.png

作者: 白开水1    时间: 2015-12-24 21:04
不是很懂啊
作者: 白开水1    时间: 2015-12-24 21:05
不是很懂啊
作者: 13885528457    时间: 2015-12-24 22:23
精度不一样
作者: holmesconan    时间: 2015-12-24 23:08
holmesconan 发表于 2015-12-24 09:47
两个精度不同.   用 float 只能保留7位 .  double  可以保留15位

自己输出一下就知道了.而且记忆深刻




欢迎光临 黑马程序员技术交流社区 (http://bbs.itheima.com/) 黑马程序员IT技术论坛 X3.2