Node.js的Buffer模块怎么使用
Node.js的Buffer模块怎么使用
这篇文章主要介绍“Node.js的Buffer模块怎么使用”,在日常操作中,相信很多人在Node.js的Buffer模块怎么使用问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”Node.js的Buffer模块怎么使用”的疑惑有所帮助!接下来,请跟着小编一起来学习吧!
二进制流是大量的二进制数据的集合。由于通常情况下二进制流的大小挺大的,因此二进制流一般不会一起运送,而会在运输前切分成小块然后逐一发送。
当数据处理单元暂时不再接收其他数据流时,剩余的数据将会被保留在缓存中,直到数据处理单元准备好接收更多数据为止。
Node.js 服务器一般需要在文件系统中进行读写,而文件在存储层面而言其实都是二进制流。除此之外,Node.js 还能与 TCP 流一起使用,让 TCP 流在不可靠的互联网络上提供可靠的端到端字节流保障通信。
发送给接收者的数据流会被缓冲,直到接收者准备接收更多要处理的数据为止。这就是 Node.js 处理临时数据部分的工作内容 —— 在 V8 引擎外部管理和存储二进制数据。
让我们一起深入缓冲区(Buffer
)的各种使用方法,了解更多有关它们的信息以及一起学习如何在 Node.js 程序中使用它们吧。
Node.js Buffer 的方法
Node.js 缓冲模块的最大优势,其实就是它是内置于 Node.js 中的,因此我们可以在任何我们想要使用它的地方使用它。
让我们一起浏览一些重要的 Node.js 缓冲模块的方法吧。
Buffer.alloc()
此方法将创建一个新的缓冲区,但是分配的大小不是固定的。当我们调用此方法时,可以自行分配大小(以字节为单位)。
constbuf=Buffer.alloc(6)//这会创建一个6字节的缓冲区console.log(buf)//<Buffer000000000000>
Buffer.byteLength()
如果我们想要获取缓冲区的长度,我们只需调用 Buffer.byteLength()
就行了。
varbuf=Buffer.alloc(10)varbuffLen=Buffer.byteLength(buf)//检查缓冲区长度console.log(buffLen)//10
Buffer.compare()
通过使用 Buffer.compare()
我们可以比较两个缓冲区,此方法的返回值是 -1
,0
,1
中的一个。
译者注:buf.compare(otherBuffer);
这一句调用会返回一个数字 -1
,0
,1
,分别对应 buf
在 otherBuffer
之前,之后或相同。
varbuf1=Buffer.from('Harsh')varbuf2=Buffer.from('Harsg')vara=Buffer.compare(buf1,buf2)console.log(a)//这会打印0varbuf1=Buffer.from('a')varbuf2=Buffer.from('b')vara=Buffer.compare(buf1,buf2)console.log(a)//这会打印-1varbuf1=Buffer.from('b')varbuf2=Buffer.from('a')vara=Buffer.compare(buf1,buf2)console.log(a)//这会打印1
Buffer.concat()
顾名思义,我们可以使用此函数连接两个缓冲区。当然,就像字符串一样,我们也可以连接两个以上的缓冲区。
varbuffer1=Buffer.from('x')varbuffer2=Buffer.from('y')varbuffer3=Buffer.from('z')vararr=[buffer1,buffer2,buffer3]console.log(arr)/*buffer,!concat[<Buffer78>,<Buffer79>,<Buffer7a>]*///通过Buffer.concat方法连接两个缓冲区varbuf=Buffer.concat(arr)console.log(buf)//<Buffer78797a>concatsuccessful
Buffer.entries()
Buffer.entries()
会用这一缓冲区的内容创建并返回一个 [index, byte] 形式的迭代器。
varbuf=Buffer.from('xyz')for(aofbuf.entries()){console.log(a)/*这个会在控制台输出一个有缓冲区位置与内容的字节的数组[0,120][1,121][2,122]*/}
Buffer.fill()
我们可以使用 Buffer.fill()
这个函数将数据插入或填充到缓冲区中。更多信息请参见下文。
constb=Buffer.alloc(10).fill('a')console.log(b.toString())//aaaaaaaaaa
Buffer.includes()
像字符串一样,它将确认缓冲区是否具有该值。我们可以使用 Buffer.includes()
方法来实现这一点,给定方法根据搜索返回一个布尔值,即 true
或 false
。
constbuf=Buffer.from('thisisabuffer')console.log(buf.includes('this'))//trueconsole.log(buf.includes(Buffer.from('abufferexample')))//false
Buffer.isEncoding()
我们可能知道二进制文件必须进行编码,那么如果我们要检查数据类型是否支持字符编码该怎么办呢?我们可以使用 Buffer.isEncoding()
方法进行确认。如果支持,它将返回 true
。
console.log(Buffer.isEncoding('hex'))//trueconsole.log(Buffer.isEncoding('utf-8'))//trueconsole.log(Buffer.isEncoding('utf/8'))//falseconsole.log(Buffer.isEncoding('hey'))//false
Buffer.slice()
buf.slice()
将用于使用缓冲区的选定元素创建一个新缓冲区 —— 对缓冲区进行切割时,将创建一个新缓冲区,其中包含要在新缓冲区切片中找到的项目的列表。
vara=Buffer.from('uvwxyz');varb=a.slice(2,5);console.log(b.toString());//wxy
Buffer.swapX()
Buffer.swapX()
用于交换缓冲区的字节顺序。使用 Buffer.swapX()
(此处 X
可以为 16, 32, 64)来交换 16 位,32 位和 64 位缓冲区对象的字节顺序。
constbuf1=Buffer.from([0x1,0x2,0x3,0x4,0x5,0x6,0x7,0x8])console.log(buf1)//<Buffer0102030405060708>//交换16位字节顺序buf1.swap16()console.log(buf1)//<Buffer0201040306050807>//交换32位字节顺序buf1.swap32()console.log(buf1)//<Buffer0304010207080506>//交换64位字节顺序buf1.swap64()console.log(buf1)//<Buffer0605080702010403>
Buffer.json()
它可以帮助我们从缓冲区创建 JSON 对象,而该方法将返回 JSON 缓冲区对象,
constbuf=Buffer.from([0x1,0x2,0x3,0x4,0x5,0x6,0x7,0x8]);console.log(buf.toJSON());//{"type":"Buffer",data:[1,2,3,4,5,6,7,8]}
到此,关于“Node.js的Buffer模块怎么使用”的学习就结束了,希望能够解决大家的疑惑。理论与实践的搭配能更好的帮助大家学习,快去试试吧!若想继续学习更多相关知识,请继续关注亿速云网站,小编会继续努力为大家带来更多实用的文章!
推荐阅读
-
php 压缩CSS代码
-
node中的buffer有什么用
node中的buffer有什么用本文小编为大家详细介绍“node中...
-
如何创建Node.js应用
-
如何使用npm命令安装Node.js模块
如何使用npm命令安装Node.js模块这篇文章主要介绍“如何使用...
-
Node.js进程退出的原理是什么
-
本地Vue项目请求本地Node.js服务器如何配置
-
node.js的path模块怎么用
node.js的path模块怎么用这篇文章主要介绍了node.js...
-
Node.js中module.exports和exports使用误区是什么
-
Web 全栈开发利器Cloud IDE怎么用
-
Node.js中的eventloop怎么用