Конвертировать Double в двоичное представление? - PullRequest
11 голосов
/ 15 июня 2011

Я пытался преобразовать double в его двоичное представление, но использование этого Long.toBinaryString(Double.doubleToRawLongBits(d)) не помогает, так как у меня большие числа, что Long не может их сохранить, т.е. 2^900.

Ответы [ 5 ]

25 голосов
/ 15 июня 2011

Long.toBinaryString(Double.doubleToRawLongBits(d)) работает нормально.

System.out.println("0:                0b" + Long.toBinaryString(Double.doubleToRawLongBits(0D)));
System.out.println("1:                0b" + Long.toBinaryString(Double.doubleToRawLongBits(1D)));
System.out.println("2:                0b" + Long.toBinaryString(Double.doubleToRawLongBits(2D)));
System.out.println("2^900:            0b" + Long.toBinaryString(Double.doubleToRawLongBits(Math.pow(2, 900))));
System.out.println("Double.MAX_VALUE: 0b" + Long.toBinaryString(Double.doubleToRawLongBits(Double.MAX_VALUE)));

/*
    prints:
    0:                0b0
    1:                0b11111111110000000000000000000000000000000000000000000000000000
    2:                0b100000000000000000000000000000000000000000000000000000000000000
    2^900:            0b111100000110000000000000000000000000000000000000000000000000000
    Double.MAX_VALUE: 0b111111111101111111111111111111111111111111111111111111111111111
*/
4 голосов
/ 10 августа 2015

Возможно, вы захотите обработать целую и дробную часть:

public String toBinary(double d, int precision) {
    long wholePart = (long) d;
    return wholeToBinary(wholePart) + '.' + fractionalToBinary(d - wholePart, precision);
}

private String wholeToBinary(long l) {
    return Long.toBinaryString(l);
}

private String fractionalToBinary(double num, int precision) {
    StringBuilder binary = new StringBuilder();
    while (num > 0 && binary.length() < precision) {
        double r = num * 2;
        if (r >= 1) {
            binary.append(1);
            num = r - 1;
        } else {
            binary.append(0);
            num = r;
        }
    }
    return binary.toString();
}
1 голос
/ 15 июня 2011

Вы можете использовать BigInteger для хранения вашего большого числа и метод BigInteger.toString () для получения его двоичного представления.

BigInteger bigNum = new BigInteger(sYourNum);
System.out.println( bigNum.toString(2) );
0 голосов
/ 15 июня 2011

Вы можете использовать Double.toHexString (d), а затем преобразовать шестнадцатеричную строку в двоичную, используя цикл for и StringBuilder.

0 голосов
/ 15 июня 2011

Вы пытались использовать java.math.BigInteger и вызывать toString(int radix) с параметром 2?

...