• Node.js Video Tutorials

Node.js - Buffer.writeUInt16BE() 方法



NodeJS 的 **Buffer.writeUInt16BE()** 方法用於以大端序形式將一個無符號 16 位整數的值寫入緩衝區的指定偏移量處。如果值不是一個 16 位無符號整數,則返回 undefined。

語法

以下是 **Node.JS Buffer.writeUInt16BE() 方法** 的語法:

buf.writeUInt16BE(value[, offset])

引數

此方法接受兩個引數,解釋如下。

  • **value** − (必需) 要寫入緩衝區的無符號 16 位數字。

  • **offset** − 指示開始寫入位置的偏移量。偏移量大於或等於 0,並且小於或等於 buffer.length-2。預設值為 0。

返回值

**buffer.writeUInt16BE()** 方法寫入給定值並返回偏移量加上寫入的位元組數。

示例

為了建立一個緩衝區,我們將使用 NodeJS Buffer.alloc() 方法:

const buffer = Buffer.alloc(10);
buffer.writeUInt16BE(1000);
console.log(buffer);

輸出

執行時,從第 0 個位置開始的值將被寫入建立的緩衝區。上面建立的緩衝區長度為 10。因此,我們只能使用 0 到 8 的偏移量值。任何大於 8 的值都會導致 **ERR_OUT_OF_RANGE** 錯誤。

<Buffer 03 e8 00 00 00 00 00 00 00 00>

示例

在這個例子中,我們將使用緩衝區長度為 5,並且偏移量大於 buffer.length - 2。

const buffer = Buffer.alloc(5);
buffer.writeUInt16BE(1000, 5);
console.log(buffer);

輸出

internal/buffer.js:58
   throw new ERR_OUT_OF_RANGE(type || 'offset',
   ^
RangeError [ERR_OUT_OF_RANGE]: The value of "offset" is out of range. It must be >= 0 and <= 3. Received 5
   at boundsError (internal/buffer.js:58:9)
   at checkBounds (internal/buffer.js:39:5)
   at checkInt (internal/buffer.js:46:3)
   at writeU_Int16BE (internal/buffer.js:666:3)
   at Buffer.writeUInt16BE (internal/buffer.js:674:10)
   at Object.<anonymous> (C:\nodejsProject\src\testbuffer.js:2:8)
   at Module._compile (internal/modules/cjs/loader.js:816:30)
   at Object.Module._extensions..js (internal/modules/cjs/loader.js:827:10)
   at Module.load (internal/modules/cjs/loader.js:685:32)
   at Function.Module._load (internal/modules/cjs/loader.js:620:12)

示例

在這個例子中,我們將建立一個緩衝區,並從一個在範圍內的偏移量寫入。

const buffer = Buffer.alloc(10);
buffer.writeUInt16BE(123, 4);
console.log(buffer);

輸出

偏移量必須在 0 到 8 之間。上述程式碼執行後的輸出如下:

<Buffer 00 00 00 00 00 7b 00 00 00 00>
nodejs_buffer_module.htm
廣告