A股上市公司传智教育(股票代码 003032)旗下技术交流社区北京昌平校区

 找回密码
 加入黑马

QQ登录

只需一步,快速开始

© 小ㄟMò 中级黑马   /  2015-12-23 12:18  /  2226 人查看  /  15 人回复  /   0 人收藏 转载请遵从CC协议 禁止商业使用本文

除了double分配8个字节内存空间,float分配4个字节,还有其他什么区别吗?还有打印的时候,%f和%lf有什么不同?

15 个回复

倒序浏览
没人回复啊,我也想知道
回复 使用道具 举报
DOUBLE双精度,FLOAT单精度,FLOAT有效数字好像是7位 DOUBLE是16位吧
回复 使用道具 举报
不知道啊,只是来评论的,好好
回复 使用道具 举报
%f 是float  %lf  是long float
回复 使用道具 举报
海棠依旧2046 来自手机 中级黑马 2015-12-23 22:52:44
地板
double精确到后15位,float7位,书写形式上也有区别
回复 使用道具 举报
两个精度不同.   用 float 只能保留7位 .  double  可以保留15位

点评

保留的精度是指有效位还是小数位  发表于 2015-12-24 12:42
回复 使用道具 举报
小ㄟMò 来自手机 中级黑马 2015-12-24 12:47:01
8#
海棠依旧2046 发表于 2015-12-23 22:52
double精确到后15位,float7位,书写形式上也有区别

那为啥打印出来的都是6位小数
回复 使用道具 举报
double、float都是浮点型。double(双精度型)比float(单精度型)存的数据更准确些,占的空间也更大。double精度是float的两倍,所以需要更精确的计算常使用double。
回复 使用道具 举报
double、float都是浮点型。double(双精度型)比float(单精度型)存的数据更准确些,占的空间也更大。double精度是float的两倍,所以需要更精确的计算常使用double。
回复 使用道具 举报
就用一张图来说明Float为单精度,内存中占4个字节,有效数位是7位(因为有正负,所以不是8位),double为双精度,占8个字节,有效数位是16位

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

QQ截图20151224164558.png
回复 使用道具 举报
不是很懂啊
回复 使用道具 举报
不是很懂啊
回复 使用道具 举报
精度不一样
回复 使用道具 举报
holmesconan 发表于 2015-12-24 09:47
两个精度不同.   用 float 只能保留7位 .  double  可以保留15位

自己输出一下就知道了.而且记忆深刻
回复 使用道具 举报
您需要登录后才可以回帖 登录 | 加入黑马