C / C ++长到Java长

我在磁盘上有一个文件,我正在阅读它是由c / c ++代码编写的。我知道我有两个64位无符号整数要读取,但Java不支持无符号整数,所以当我执行DataInputStream.readLong()时得到的值是不正确的。 (暂时忽略字节顺序我实际上正在使用我从网上下载的名为LEDataInputStream的DIS衍生物) 这里有很多帖子谈论使用BigInteger但是用于读取bytearray的javadoc只讨论加载一个bytearray表示,而问题似乎集中在这样一个事实:有些人超出了java long类型的正边界,我我正在阅读的数据将远远不够。 我有一个MATLab / Octave脚本,它将这些长long值读取为两个32位整数,然后进行一些乘法和加法以得到它想要的答案。 我想问题是 - 如何使用BigInteger或使用[LE] DataInputStream.XXX读取64位无符号整数? 提前致谢     
已邀请:
我建议使用ByteBuffer,然后使用这样的代码来获得你想要的东西。     
您可以使用
long
作为64位值来存储无符号数据。这是一个模块,显示可以使用标准
long
类型执行大多数无符号运算。这实际上取决于你想对这个值做什么,不管这是不是问题。 编辑:处理无符号数的常用方法是扩大数据类型。这在许多情况下更简单,但不是一个要求(对于
long
使用
BigInteger
不会使事情更简单恕我直言) EDIT2:以下代码有什么问题?
long max_unsigned = 0xFFFFFFFFFFFFFFFFl;
long min_unsigned = 0;
System.out.println(Unsigned.asString(max_unsigned) + " > "
        + Unsigned.asString(min_unsigned) + " is "
        + Unsigned.gt(max_unsigned, min_unsigned));
版画
18446744073709551615 > 0 is true
    
首先你看看这个问题 也看到这个 现在使用BigInteger类
// Get a byte array
byte[] bytes = new byte[]{(byte)0x12, (byte)0x0F, (byte)0xF0};

// Create a BigInteger using the byte array
BigInteger bi = new BigInteger(bytes);

// Format to binary
String s = bi.toString(2);      // 100100000111111110000

// Format to octal
s = bi.toString(8);             // 4407760

// Format to decimal
s = bi.toString();              // 1183728

// Format to hexadecimal
s = bi.toString(16);            // 120ff0
if (s.length() % 2 != 0) {
    // Pad with 0
    s = "0"+s;
}


// Parse binary string
bi = new BigInteger("100100000111111110000", 2);

// Parse octal string
bi = new BigInteger("4407760", 8);

// Parse decimal string
bi = new BigInteger("1183728");

// Parse hexadecimal string
bi = new BigInteger("120ff0", 16);

// Get byte array
bytes = bi.toByteArray();
    

要回复问题请先登录注册