Float和Double的讲解

今天有人问我了一个特别基础的问题:就是为什么 

float s = 2.0;

不能这样写?一定要强转一下

要 float s = 2.0f;

其实 float 是不能 直接定义的,要强转的。如果一定要定义,则要float进行强转。虽然是单精度浮点型。于双精度浮点型不一样。( 上述只是代表个人意见,而不是代表CSDN意见)

接下来我就给大家来说一下他们的区别: 

float   是单浮点型,占4个字节储存空间,能表示的有效数位有7位;
double  是双浮点型,占8个字节储存空间,能表示的有效数位有16位;
float:2^23,一共七位,这意味着最多能有7位有效数字,但绝对能保证的为6位,也即float的精度为6~7位有效数字;
double:2^52,一共16位,同理,double的精度为15~16位
(浮点)数值 =      尾数    ×    底数 ^ 指数,(附加正负号)
float的指数范围为-127~128,而double的指数范围为-1023~1024,并且指数位是按补码的形式来划分的
建议数据的有效性 float 7位 double为15位

一般来讲:我们其实没有必要去死抠这些问题,我们知道就好了

请看下面的代码: 

double ss1 = 1.2;
double ss2 = 1.20;
float f1 = (float) 1.0;
 float f2 = 1.0f;
double dd1 = f1;
 //而  float f2 = dd1  ;这样写是不行的;

这就是为什么只能有精度低的wang精度高的转,反过来就不行了

希望对大家有所帮助。。

评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

androidstarjack

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值