Преобразовать байт в int и наоборот - PullRequest
1 голос
/ 25 февраля 2011

Кто-нибудь знает, как я могу преобразовать большой массив байтов, например 1000 байтов в int / long и т. Д. В Java?

Ответы [ 3 ]

2 голосов
/ 25 февраля 2011

Чтобы преобразовать byte в int в Java, у вас есть два варианта:

byte val = 0xff;
int a = val;          // a == -1
int b = (val & 0xff); // b == 0xff

В библиотеке Java нет метода для преобразования массива из одного примитивного типа в другой, вам придется делать это вручную.

2 голосов
/ 25 февраля 2011

Вы можете использовать цикл

byte[] bytes =
int[] ints = new int[bytes.length];
for(int i=0;i<bytes.length;i++)
   ints[i] = bytes[i];

Таким образом, 1000 элементов могут занять до 10 микросекунд.

0 голосов
/ 07 марта 2011

Спасибо, Пагло. Вот исправленный ответ:

public class Main {

    public static int[] convert(byte[] in) {
        int bytesPerSample = 4;
        int[] res = new int[in.length / bytesPerSample];

        for (int i = 0; i < res.length; i++) {
            int bOffset = i * bytesPerSample;
            int intVal = 0;
            for (int b = 0; b < bytesPerSample; b++) {
                int v = in[bOffset + b];
                if (b < bytesPerSample - 1) {
                    v &= 0xFF;
                }
                intVal += v << (b * 8);
            }
            res[i] = intVal;
        }

        return res;
    }

    public static byte[] convert(int[] in) {
        int bytesPerSample = 4;
        byte[] res = new byte[bytesPerSample * in.length];

        for (int i = 0; i < in.length; i++) {
            int bOffset = i * bytesPerSample;
            int intVal = in[i];
            for (int b = 0; b < bytesPerSample; b++) {
                res[bOffset + b] = (byte) (intVal & 0xFF);
                intVal >>= 8;
            }
        }

        return res;
    }

    public static void main(String[] args) {
        int[] in = {33, 1035, 8474};
        byte[] b = convert(in);
        int[] in2 = convert(b);
        System.out.println(Arrays.toString(in2));
    }

}
...