Buffer:Node.js 里处理二进制数据的 “小工具”

1. Buffer 是什么?一句话说清

Buffer 是 Node.js 里类似数组的对象,专门用来存固定长度的字节序列------ 本质就是计算机里的一段内存空间,用来搞定二进制数据的读写。

2. Buffer 的 3 个核心特点

  • 大小固定不能改:创建时就确定长度,后续没法扩容或缩容(比如创建 10 字节的 Buffer,就只能用 10 字节)。
  • 性能好:直接操作计算机内存,比普通数组处理二进制快得多。
  • 每个元素占 1 字节:Buffer 里的每个值范围是 0-255,刚好对应 1 字节(byte)的存储大小。

3. Buffer 实操:创建、转字符串、读写

3.1 3 种创建 Buffer 的方式

Node.js 里创建 Buffer 主要靠 3 个方法,各自有适用场景:

javascript 复制代码
// 1. Buffer.alloc(长度):创建空Buffer,每个字节初始值为0(安全,推荐用)
let buf1 = Buffer.alloc(10); 
console.log(buf1); // 输出:<Buffer 00 00 00 00 00 00 00 00 00 00>(10个0)

// 2. Buffer.allocUnsafe(长度):创建空Buffer,但可能残留旧内存数据(不安全,慎用)
let buf2 = Buffer.allocUnsafe(10); 
console.log(buf2); // 输出可能带随机值,比如<Buffer a3 2f ...>

// 3. Buffer.from(数据):从字符串/数组创建Buffer(最常用)
// 3.1 从字符串创建
let buf3 = Buffer.from('hello'); 
console.log(buf3); // 输出:<Buffer 68 65 6c 6c 6f>(hello的ASCII码)

// 3.2 从数组创建(数组元素是0-255的数字,对应ASCII码)
let buf4 = Buffer.from([105, 108, 111, 118, 101, 121, 111, 117]); 
console.log(buf4); // 输出:<Buffer 69 6c 6f 76 65 79 6f 75>
3.2 Buffer 转字符串:用 toString () 就行

Buffer 存的是二进制,要转成我们能看懂的字符串,直接调用toString(),默认用utf-8编码(不用额外配置):

javascript 复制代码
// 接上面的buf4(数组创建的Buffer)
let str = buf4.toString(); 
console.log(str); // 输出:iloveyou(105是i,108是l,对应起来就是iloveyou)
3.3 Buffer 读写:像操作数组一样用 []

Buffer 支持直接用[]读取或修改元素:

javascript 复制代码
// 先创建一个Buffer:from('hello')
let buf3 = Buffer.from('hello'); 

// 1. 读取:buf[索引],返回的是ASCII码
console.log(buf3[1]); // 输出:101(对应字母e)

// 2. 修改:buf[索引] = 新值(新值必须是0-255的数字)
buf3[1] = 97; // 97是字母a的ASCII码
console.log(buf3.toString()); // 输出:hallo(把e改成a了)

// 【坑】修改值超过255:会舍弃超过8位的二进制(比如256会变成0)
buf3[1] = 256; 
console.log(buf3.toString()); // 输出:hllo(256被当成0,对应空字符)
相关推荐
web安全工具库7 小时前
Linux 高手进阶:Vim 核心模式与分屏操作详解
linux·运维·服务器·前端·数据库
一枚前端小能手7 小时前
🔥 SSR服务端渲染实战技巧 - 从零到一构建高性能全栈应用
前端·javascript
Komorebi_99997 小时前
Vue3 provide/inject 详细组件关系说明
前端·javascript·vue.js
用户1412501665277 小时前
一文彻底掌握 ECharts:从配置解读到实战应用
前端
LRH7 小时前
React 架构设计:从 stack reconciler 到 fiber reconciler 的演进
前端
VIjolie7 小时前
文档/会议类应用的协同同步机制(OT/CRDT简要理解)
前端
不一样的少年_7 小时前
【前端效率工具】:告别右键另存,不到 50 行代码一键批量下载网页图片
前端·javascript·浏览器
golang学习记7 小时前
从0死磕全栈之Next.js 企业级 next.config.js 配置详解:打造高性能、安全、可维护的中大型项目
前端
1024小神7 小时前
next项目使用状态管理zustand说明
前端