Ответ 1
Оказывается, это возможно, хотя это меня удивило. Раздел 3.10.2 JLS предоставляет структуру литералов с плавающей запятой, включая шестнадцатеричныйFloatingPointLiteral.
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)