freeCodeCamp/guide/chinese/nodejs/buffer/index.md

2.7 KiB
Raw Blame History

title localeTitle
Nodejs- Buffer Nodejs-缓冲区

缓冲

二进制只是一个集合或10的集合。二进制中的每个数字一组中的每个1和0称为_一位_ 。计算机将数据转换为此二进制格式以存储和执行操作。例如,以下是五个不同的二进制文件:

10, 01, 001, 1110, 00101011

JavaScript在其核心API中没有字节类型数据。为了处理二进制数据Node.js包括一个带有名为Buffer的全局模块的二进制缓冲区实现。

创建缓冲区

您可以通过不同的方式在Node.js中创建缓冲区。您可以使用10个字节的大小创建一个空缓冲区。

const buf1 = Buffer.alloc(10); 

从UTF-8编码的字符串创建如下

const buf2 = Buffer.from('Hello World!'); 

创建缓冲区时有不同的可接受编码:

  • ASCII
  • UTF-8
  • BASE64
  • LATIN1
  • 二进制
  • 十六进制

Buffer API中分配了三个单独的函数来使用和创建新的缓冲区。在上面的例子中我们看到了alloc()from() 。第三个是allocUnsafe()

const buf3 = Buffer.allocUnsafe(10); 

返回时,此函数可能包含需要覆盖的旧数据。

与缓冲区的交互

可以使用Buffer API进行不同的交互。我们将在这里介绍他们中的大多数。让我们从将缓冲区转换为JSON开始。

let bufferOne = Buffer.from('This is a buffer example.'); 
 console.log(bufferOne); 
 
 // Output: <Buffer 54 68 69 73 20 69 73 20 61 20 62 75 66 66 65 72 20 65 78 61 6d 70 6c 65 2e> 
 
 let json = JSON.stringify(bufferOne); 
 console.log(json); 
 
 // Output: {"type": "Buffer", "data": [84,104,105,115,32,105,115,32,97,32,98,117,102,102,101,114,32,101,120,97,109,112,108,101,46]} 

JSON指定要转换的对象类型是Buffer及其数据。将空缓冲区转换为JSON将向我们显示它只包含零。

const emptyBuf = Buffer.alloc(10); 
 
 emptyBuf.toJSON(); 
 
 // Output: { "type": "Buffer", "data": [ 0, 0, 0, 0, 0, 0, 0, 0, 0, 0 ] } 

请注意Buffer API还提供了一个直接函数toJSON()来将缓冲区转换为JSON对象。要检查缓冲区的大小我们可以使用length方法。

emptyBuf.length; 
 // Output: 10 

现在让我们将缓冲区转换为可读字符串在我们的例子中是utf-8编码的。

console.log(bufferOne.toString('utf8')); 
 
 // Output: This is a buffer example. 

.toString()默认情况下将缓冲区转换为utf-8格式字符串。这是解码缓冲区的方法。如果指定编码则可以将缓冲区转换为其他编码

console.log(bufferOne.toString('base64'));