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

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。

 

  • 2
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值