Подтвердить что ты не робот

Java-шестнадцатеричный базовый двойной литерал

Я изучаю сертификацию java. И я интересуюсь литературой в java. Я знаю, что можно сделать что-то вроде этого:

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

Также это возможно для переменных с плавающей запятой:

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

Поэтому я логически думал с этими примерами, что то же самое применимо и для шестнадцатеричных. Точно так же, как я могу добавить L для длинных литералов, я мог бы добавить "d" или "f", но логика ошибочна, так как "F" и "D" являются допустимыми шестнадцатеричными значениями.

Невозможно сделать что-то вроде этого:

double d = 0xAAAAAAAAAAAAAAAAAAd;

Это просто не разрешено Java или есть простой способ сделать это, что я не знаю?

4b9b3361

Ответ 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)