2

我有一个包含 java ByteArray 的文件。

字节.inc

byte MyByteArray[] = new byte[]
{
(byte) 0x4D,(byte) 0x5A,(byte) 0x50,(byte) 0x00,(byte) 0x02,(byte) 0x00,(byte) 0x00,
(byte) 0x00,(byte) 0x04,(byte) 0x00,(byte) 0x0F,(byte) 0x00,(byte) 0xFF,(byte) 0xFF,
(byte) 0x00,(byte) 0x00,(byte) 0xB8,(byte) 0x00,(byte) 0x00,(byte) 0x00,(byte) 0x00,
(byte) 0x00,(byte) 0x00,(byte) 0x00,(byte) 0x40,(byte) 0x00,(byte) 0x1A,(byte) 0x00,
(byte) 0x00,(byte) 0x00,(byte) 0x00,(byte) 0x00,(byte) 0x00,(byte) 0x00,(byte) 0x00,
(byte) 0x00,(byte) 0x00,(byte) 0x00,(byte) 0x00,(byte) 0x00,(byte) 0x00,(byte) 0x00,
(byte) 0x00,(byte) 0x00,(byte) 0x00,(byte) 0x00,(byte) 0x00,(byte) 0x00,(byte) 0x00,
(byte) 0x00,(byte) 0x00,(byte) 0x00,(byte) 0x00,(byte) 0x00,(byte) 0x00,(byte) 0x00,
(byte) 0x00,(byte) 0x00,(byte) 0x00,(byte) 0x00,(byte) 0x00,(byte) 0x01,(byte) 0x00,
(byte) 0x00,(byte) 0x00,(byte) 0x00,(byte) 0x00,
};

完整的文件 (bytes.inc) 是 283kb,这对于编译器来说太大了,无法插入到特定的类中。我尝试逐字节读取文件,然后将其从字符串转换为实际字节,因为读取文件只会产生字符串,当我这样做并将字节转换回来时,它会显示字节的文本表示,而不是它的实际转换。我如何才能获得生成完整 ByteArray 的能力而不将其包含在一个巨大的方法中?

4

1 回答 1

1

一种选择是将实际字节存储在文件中并使用Files.readAllBytes(path)

Path path = Paths.get("path/to/file");
byte[] bytes = Files.readAllBytes(path);

另一种选择是将字节作为文本保存在文件中,,并使用以下代码:

FileReader file = new FileReader("bytes.txt");
Scanner scanner = new Scanner(file);
scanner.useDelimiter(",");
ByteBuffer byteBuffer = new ByteBuffer(0);
while (scanner.hasNext()) {
    byteBuffer.append(Byte.decode(scanner.next().trim()));
}
scanner.close();

字节文件如下所示:

0x4D,0x5A,0x50,0x00,0x02
于 2013-06-09T12:29:08.527 回答