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

90 lines
2.7 KiB
Markdown
Raw Normal View History

---
title: Nodejs- Buffer
localeTitle: Nodejs-缓冲区
---
## 缓冲
二进制只是一个集合或`1`和`0`的集合。二进制中的每个数字一组中的每个1和0称为_一位_ 。计算机将数据转换为此二进制格式以存储和执行操作。例如,以下是五个不同的二进制文件:
`10, 01, 001, 1110, 00101011`
JavaScript在其核心API中没有字节类型数据。为了处理二进制数据Node.js包括一个带有名为`Buffer`的全局模块的二进制缓冲区实现。
### 创建缓冲区
您可以通过不同的方式在Node.js中创建缓冲区。您可以使用10个字节的大小创建一个空缓冲区。
```javascript
const buf1 = Buffer.alloc(10);
```
从UTF-8编码的字符串创建如下
```javascript
const buf2 = Buffer.from('Hello World!');
```
创建缓冲区时有不同的可接受编码:
* ASCII
* UTF-8
* BASE64
* LATIN1
* 二进制
* 十六进制
Buffer API中分配了三个单独的函数来使用和创建新的缓冲区。在上面的例子中我们看到了`alloc()`和`from()` 。第三个是`allocUnsafe()` 。
```javascript
const buf3 = Buffer.allocUnsafe(10);
```
返回时,此函数可能包含需要覆盖的旧数据。
### 与缓冲区的交互
可以使用Buffer API进行不同的交互。我们将在这里介绍他们中的大多数。让我们从将缓冲区转换为JSON开始。
```javascript
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将向我们显示它只包含零。
```javascript
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`方法。
```javascript
emptyBuf.length;
// Output: 10
```
现在让我们将缓冲区转换为可读字符串在我们的例子中是utf-8编码的。
```javascript
console.log(bufferOne.toString('utf8'));
// Output: This is a buffer example.
```
`.toString()`默认情况下将缓冲区转换为utf-8格式字符串。这是解码缓冲区的方法。如果指定编码则可以将缓冲区转换为其他编码
```javascript
console.log(bufferOne.toString('base64'));
```