1

我正在尝试创建附加缓冲区的方法。

这是代码,结果很奇怪:

   var offset = 0
   var a = new Buffer(0)
   var b = new Buffer('test')

   offset = a.length
   a.length += b.length
   a.copy(b, offset)
   console.log(a.toString())
   // everything works normaly
   // returns: test

   b = new Buffer('hello')
   offset = a.length
   a.length += b.length
   a.copy(b, offset)
   console.log(a.toString())
   // code the same
   // but returns: test<Buff
   // nor: testhello

   // at the third time code doesn't works and raise error: targetStart out of bounds

我做错了什么?

4

1 回答 1

5

:编辑:

被这个问题弄糊涂了。我以为他会处理相同类型的缓冲区。

缓冲区无法调整大小,因为它们在 Node.js 中由固定大小定义,因此最好的选择是使用这样的函数

   function concat(buffers) {

    if (!Array.isArray(buffers)) {
      buffers = Array.prototype.slice.call(arguments);
    }

    var buffersToConcat = [], length = 0;
    buffers.forEach(function (buffer) {
        if (!Buffer.isBuffer(buffer)) {
          buffer = new Buffer(buffer);
        }
        length += buffer.length;
        buffersToConcat.push(buffer);
    });

    var concatinatedBuffer = new Buffer(length), index = 0;
    buffersToConcat.forEach(function (buffer) {
      buffer.copy(concatinatedBuffer, index, 0, buffer.length);
      index += buffer.length;
    });

    return concatinatedBuffer;
  }

你做错了什么? 您试图通过 += 方法来操纵内存中固定大小分配的长度。因此它抛出了异常,因为 += 运算符显然没有重新分配内存

*我们在这里做什么 *

非常简单,我们只是从参数缓冲区中创建一个新缓冲区。

于 2012-06-07T14:34:51.860 回答