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)
我正在学习 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)