Java 十六进制基双字面量

Java hexadecimal base double literal

我正在学习 java 认证。我对 java 文字很好奇。 我知道可以这样做:

int i = 0xAA;
long l = 0xAAL;

对于浮点变量也是可能的:

double d = 123d;
float f = 123f;

所以我从逻辑上认为这些例子同样适用于十六进制。就像我可以为长文字添加 L 一样,我可以添加 'd' 或 'f' 但逻辑存在缺陷,因为 'F' 和 'D' 是有效的十六进制值。

不可能做这样的事情:

double d = 0xAAAAAAAAAAAAAAAAAAd;

这是 Java 不允许的,还是有一种我不知道的简单方法?

事实证明 可能的,尽管这让我感到惊讶。 Section 3.10.2 of the JLS给出了浮点字面量的结构,包括HexadecimalFloatingPointLiteral.

public class Test {

    public static void main(String[] args) {
        double d1 = 0xAAAAAAAAAAAAAAAAAAp0d;
        double d2 = 0x1.8p1d;

        System.out.println(d1); // A very big number
        System.out.println(d2); // 24 = 1.5 * 2^1
    }
}

p 需要作为二进制指数的一部分 - p 之后的值是将值左移的位数。其他示例:

0x1.4p0d => 1.25 (binary 0.01 shifted 0 bits)
0x8p-4d => 0.5 (binary 1000 shifted *right* 4 bits)