为什么java中定义long、float后要跟L/l、F/f

本文深入探讨了Java中float和double两种浮点型变量的使用细节,包括默认类型、精度丢失、强制类型转换及最佳实践,是Java初学者和进阶者的必备指南。

1、float

浮点型有两种形式double或者float,描述小数时默认的double类型。

定义:double num = 10.2;

10.2是小数,默认为double类型。将它给了double。是从double到double。

定义:float num = 10.2;

10.2是小数,默认为double类型。将它给了double。是从float到double。是从小类型向大类型转换,会发生精度丢失,所以在编译时会发生错误,想要转换,必须强制类型转换(告诉编译器,你知道会发生丢失,但就是要变)。可以这么写:

float num = (float)10.2;  这样就不会编译过不了。

所以我们在定义float时要写成:float num = 10.2F;或者float num = 10.2f;

2、double

在java中,任何一个整型常量都是int类型。

定义:long num = 10;

10是整数,默认为int类型。将它给了long,是从int到long,是小类型转大类型,不需要强制类型转换,编译时也不会报错。

但是在我们定义时最好写成long num = 10L;这是从long到long的赋值,不需要转换。

建议写成long num = 10L;,而不是long num = 10l;(小写的L),会让人误以为时101。

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值