将Double转换为二进制表示?

时间:2011-06-15 15:01:54

标签: java binary double type-conversion long-integer

我尝试将double转换为其二进制表示形式,但使用此Long.toBinaryString(Double.doubleToRawLongBits(d))无效,因为我有大数字,Long无法存储它们,即2^900

6 个答案:

答案 0 :(得分:25)

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
*/

答案 1 :(得分:4)

您可能希望处理整个和小数部分:

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();
}

答案 2 :(得分:1)

您可以使用BigInteger来保存您的大号和BigInteger.toString()方法来检索它的二进制表示。

BigInteger bigNum = new BigInteger(sYourNum);
System.out.println( bigNum.toString(2) );

答案 3 :(得分:0)

您是否尝试过使用java.math.BigInteger并使用参数2来调用toString(int radix)

答案 4 :(得分:0)

这是一个小片段,它将double的小数部分转换为二进制格式:

String convertToBinary(double number) {
    int i=1;
    String num="0.";
    double temp,noofbits=32;
    while (i<=noofbits && number>0) {
        number=number*2;
        temp=Math.floor(number);
        num+=(int)temp;
        number=number-temp;
        i++;
    }

其中noofbits给出您希望小数部分受限的位大小。 对于整数部分,请直接使用Integer.toBinaryString()以及double的下限值,并将其追加到小数二进制字符串中。

答案 5 :(得分:-1)

您可以使用Double.toHexString(d),然后使用for循环和StringBuilder将十六进制字符串转换为二进制字符串。