2 Java中的科学计数法
在Java中,当Double的取值符合某条件时,将会以科学计数法的方式显示(下面是个人测试的结果,非从文档中得到的结论):
@Test
public void testPrintScientificNotation() {
//整数部分位数大于等于8时开始以科学计数法显示
System.out.println(-12345678.0);
System.out.println(12345678.0);
//整数位为0,当小数位以0开始连续出现大于等于3时开始以科学计数法显示
System.out.println(0.0001);
System.out.println(-0.0001);
}
结果
-1.2345678E7
1.2345678E7
1.0E-4
-1.0E-4
很多时候,我们需要做一个统一,要么全部以科学计数法输出,要么就全部显示为普通计数。
根据网上的资料,主要提及NumberFormat、DecimalFormat、BigDecimal这三种API实现方式。
https://www.cnblogs.com/zhanyao/p/6583207.html
下划线
Java 7 中有一个深思熟虑的补充:我们可以在数字字面量中包含下划线 _
,以使结果更清晰。这对于大数值的分组特别有用。代码示例:
// operators/Underscores.java public class Underscores { public static void main(String[] args) { double d = 341_435_936.445_667; System.out.println(d); int bin = 0b0010_1111_1010_1111_1010_1111_1010_1111; System.out.println(Integer.toBinaryString(bin)); System.out.printf("%x%n", bin); // [1] long hex = 0x7f_e9_b7_aa; System.out.printf("%x%n", hex); } }
输出结果:
3.41435936445667E8
101111101011111010111110101111
2fafafaf
7fe9b7aa
下面是合理使用的规则:
- 仅限单
_
,不能多条相连。 - 数值开头和结尾不允许出现
_
。 F
、D
和L
的前后禁止出现_
。- 二进制前导
b
和 十六进制x
前后禁止出现_
。
[1] 注意 %n
的使用。熟悉 C 风格的程序员可能习惯于看到 \n
来表示换行符。问题在于它给你的是一个“Unix风格”的换行符。此外,如果我们使用的是 Windows,则必须指定 \r\n
。这种差异的包袱应该由编程语言来解决。这就是 Java 用 %n
实现的可以忽略平台间差异而生成适当的换行符,但只有当你使用 System.out.printf()
或 System.out.format()
时。对于 System.out.println()
,我们仍然必须使用 \n
;如果你使用 %n
,println()
只会输出 %n
而不是换行符。