Как преобразовать байтовый массив в два длинных значения? - PullRequest
2 голосов
/ 22 января 2011

Я читаю 16-байтовый массив (byte[16]) из JDBC ResultSet с rs.getBytes("id"), и теперь мне нужно преобразовать его в два длинных значения.Как я могу это сделать?

Это код, который я пробовал, но я, вероятно, неправильно использовал ByteBuffer.

byte[] bytes = rs.getBytes("id");
System.out.println("bytes: "+bytes.length); // prints "bytes: 16"

ByteBuffer buffer = ByteBuffer.allocate(16);
buffer = buffer.put(bytes);

// throws an java.nio.BufferUnderflowException
long leastSignificant = buffer.getLong();
long mostSignificant = buffer.getLong();

Я сохранил байтовый массив в базе данных, используя:

byte[] bytes = ByteBuffer.allocate(16)
    .putLong(leastSignificant)
    .putLong(mostSignificant).array();

Ответы [ 4 ]

4 голосов
/ 22 января 2011

Вы можете сделать

ByteBuffer buffer = ByteBuffer.wrap(bytes);
long leastSignificant = buffer.getLong(); 
long mostSignificant = buffer.getLong(); 
2 голосов
/ 22 января 2011

Вам нужно сбросить ByteBuffer с помощью метода flip() после того, как вы вставите в него байты (тем самым позволив вызовам getLong () прочитать из начального смещения 0):

buffer.put(bytes);     // Note: no reassignment either

buffer.flip();

long leastSignificant = buffer.getLong();
long mostSignificant = buffer.getLong();
1 голос
/ 25 октября 2012

Попробуйте это:

LongBuffer buf = ByteBuffer.wrap(bytes).asLongBuffer();
long l1 = buf.get();
long l2 = buf.get();
1 голос
/ 22 января 2011
long getLong(byte[] b, int off) {
    return ((b[off + 7] & 0xFFL) << 0) +
           ((b[off + 6] & 0xFFL) << 8) +
           ((b[off + 5] & 0xFFL) << 16) +
           ((b[off + 4] & 0xFFL) << 24) +
           ((b[off + 3] & 0xFFL) << 32) +
           ((b[off + 2] & 0xFFL) << 40) +
           ((b[off + 1] & 0xFFL) << 48) +
           (((long) b[off + 0]) << 56);
}

long leastSignificant = getLong(bytes, 0);
long mostSignificant = getLong(bytes, 8);
...