Java 十六进制基双字面

2022-09-01 03:10:08

我正在学习Java认证。我对java文字感到好奇。我知道可以做这样的事情:

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

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

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

因此,我从逻辑上认为,通过这些例子,十六进制也是如此。就像我可以为长字面量添加L一样,我可以添加“d”或“f”,但逻辑是有缺陷的,因为“F”和“D”是有效的十六进制值。

不可能做这样的事情:

double d = 0xAAAAAAAAAAAAAAAAAAd;

这是Java所不允许的,还是有一种我不知道的简单方法可以做到这一点?


答案 1

事实证明这是可能的,尽管这让我感到惊讶。JLS 的第 3.10.2 节给出了浮点文本的结构,包括十六进制浮动点Literal

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
    }
}

作为二进制指数的一部分是必需的 - 后面的值是将值向左移动的位数。其他示例:pp

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

答案 2