0

我尝试通过 ByteBuffer 访问 byte[] 以表示我定义的文件类型。byte[] 中的第一个位置包含一些元数据并使用位操作进行处理。所以它们根本不代表一个字符。

我想在某个固定位置添加文件数据(例如字符)。

byte[] file_portion包含一个大文件的一部分:开始部分。其中包括带有元数据的标头。 content是一个字符串,其中包含我要添加到该缓冲区的信息。start_pos 是从内容中保存新文件数据的第一个位置。

ByteBuffer my_content = ByteBuffer.allocate(this.file_portion.length);
content_buffer.wrap(this.file_portion);

for (int i = 0; i < content.length(); i++) {
    char tmp = content.toCharArray()[i];
    my_content.put(this.start_pos + i, (byte) tmp)
}

如果我重新映射这个,我会得到一个垃圾和空虚:

CharBuffer debug = my_content.asCharBuffer();
System.out.println("debug " + debug);

我可以理解第一个位置是否显示损坏的字符......但没有一个位置是正确的。

4

2 回答 2

2

你知道在 Java 中一个 char 占用两个字节吗?

于 2011-01-13T21:13:17.297 回答
2

如果您将字符添加到 ByteBuffer 并期望它们可以通过 CharBuffer 视图读取,则应该使用 putChar(...) 而不是 put(...)。

已编辑:根据 OP 评论。

例如:

char[] chars = content.toCharArray();  // removed from loop per leonbloy's excellent comment  
CharBuffer cbuf = my_content.asCharBuffer();

for (int i = 0; i < content.length(); i++) {
    cbuf.putChar(chars[i]);
}

CharBuffer debug = my_content.asCharBuffer();
System.out.println(debug);

my_content.position(my_content.position() + 2*chars.length);

否则, CharBuffer 会将您的两个连续字节作为单个字符读取。现在 cbuf 缓冲区将在您的字节缓冲区停止的同一点开始加载字符。加载所有字符后,您的原始 ByteBuffer 将被定位到下一个位置。希望这是您正在寻找的。

于 2011-01-13T21:18:38.887 回答