Java核心技术 卷1

  1. 长整型数值有一个后缀L或l(如4000000000L)。
  2. 十六进制数值有一个前缀0x或0X(如0xCAFE)。
  3. 八进制有一个前缀0,例如,010对应八进制中的8。很显然,八进制表示法比较容易混淆,所以建议最好不要使用八进制常数。
  4. 加上前缀0b或0B就可以写二进制数。例如,0b1001就是9。
  5. 可以为数字字面量加下划线,如用1_000_000表示一百万。这些下划线只是为了让人更易读。Java编译器会去除这些下划线。
  6. 应用程序都采用double类型。在很多情况下,float类型的精度很难满足需求。实际上,只有很少的情况适合使用float类型,例如,需要单精度数据的库,或者需要存储大量数据。
    float类型的数值有一个后缀F或f(例如,3.14F)。没有后缀F的浮点数值(如3.14)默认为double类型。当然,也可以在浮点数值后面添加后缀D或d(例如,3.14D)。
  7. 可以使用十六进制表示浮点数值。例如,0.125=2e-3可以表示成0x1.0p-3。在十六进制表示法中,使用p表示指数。注意,p的基数是2。
    System.out.println(0x1p-3); = 1*2e-3
    System.out.println(Math.pow(2, -3));
  8. 常量Double.POSITIVE_INFINITY、Double.NEGATIVE_INFINITY和Double.NaN但在实际应用中很少遇到。特别要说明的是,不能这样检测一个特定值是否等于Double.NaN:
    [图片]
    所有“非数值”的值都认为是不相同的。然而,可以使用Double.isNaN方法:
    [图片]
    警告:浮点数值不适用于无法接受舍入误差的金融计算中。例如,命令System.out.println(2.0–1.1)将打印出0.8999999999999999,而不是人们想象的0.9。这种舍入误差的主要原因是浮点数值采用二进制系统表示,而在二进制系统中无法精确地表示分数1/10。这就好像十进制无法精确地表示分数1/3一样。如果在数值计算中不允许有任何舍入误差,就应该使用BigDecimal类。
  9. 我们强烈建议不要在程序中使用char类型,除非确实需要处理UTF-16代码单元。最好将字符串作为抽象数据类型处理(有关这方面的内容将在3.6节讨论)。
  10. 逐一声明每一个变量可以提高程序的可读性。
  11. 在Java中,变量的声明尽可能地靠近变量第一次使用的地方,这是一种良好的程序编写风格。
  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值