Node.js Buffer模块功能及常用方法实例分析


Posted in Javascript onJanuary 05, 2019

本文实例讲述了Node.js Buffer模块功能及常用方法。分享给大家供大家参考,具体如下:

Buffer模块

alloc()方法

alloc(size,fill,encoding)可以分配一个大小为 size 字节的新建的 Buffer,size默认为0

var buf = Buffer.alloc(10);

参数fill为填充的数据,只要指定了fill就会调用Buffer.fill(fill) 初始化这个Buffer对象

var buf = Buffer.alloc(10,0xff);//可以为十六进制的数据

allocUnsafe()方法

Unsafe(size)顾名思义就是不安全的方法,因为以这种方式创建的 Buffer 实例的底层内存是未初始化的。甚至可能包含到敏感数据,所以通过fill()方法帮助初始化

buf = Buffer.allocUnsafe(10);
buf.fill(0);

allocUnsafeSlow()方法

allocUnsafeSlow()就是不从buffer缓冲区里分配,直接从操作系统分配,Slow指的是没有从缓冲池里高效分配

buf = Buffer.allocUnsafeSlow(10);

from()方法

from()方法可以分配一个buffer对象,用来存放这个字符串的二进制对象,因此Buffer的内容可以通过[]进行访问

buf = Buffer.from("HelloWorld!");//from(array)
console.log(buf);
buf = Buffer.from([123,22,24,36]);
console.log(buf);
//重建一个buffer,把原来Buffer的数据拷贝给新的buffer
buf2 = Buffer.from(buf);
console.log(buf2);
//buf[index] index取值范围[0,len-1]
console.log(buf[0],buf[1]);

大尾与小尾形式写入存储

writeInt32BE(value,offset)第一个参数为写入的数据,第二个参数从哪个位置开始写入 ,表示其以大尾(大端)形式写入
writeInt32LE(value,offset)以小尾(小端)的形式写入数据

//以大尾的形式存放,4个字节的整数
buf.writeInt32BE(65535,0);
console.log(buf);
//以小尾的方式写入
buf.writeInt32LE(65535,0);
console.log(buf);

大尾小尾形式读取数据

readInt32LE(offset)是指以小尾整型形式读取数据
readFloatLE(offset)是指以小尾浮点形式读取数据

var value = buf.readInt32LE(0);
console.log(value);
buf.writeFloatLE(3.16,0);
console.log(buf.readFloatLE(0));

读取数据的各种方式

//读取长度
var len = Buffer.byteLength("HelloWorld");
console.log(len);
buf = Buffer.alloc(4*4);
buf.writeInt32LE(65535,0);
buf.writeInt32LE(65535,4);
buf.writeInt32LE(65535,8);
buf.writeInt32LE(65535,12);
console.log(buf);
buf.swap32();
console.log(buf);
//用高位的方式读取
console.log(buf.readInt32BE(0));
console.log(buf.readInt32BE(4));
console.log(buf.readInt32BE(8));
console.log(buf.readInt32BE(12));
for (var i of buf.values()) {
  console.log(i);
}

转换

//以二进制方式转为字符串
console.log(buf.toString('hex'));
console.log(buf.toJSON());
buf.fill('A');
console.log(buf);
console.log(buf.toString('utf8'));

希望本文所述对大家nodejs程序设计有所帮助。

Javascript 相关文章推荐
javascript定义变量时加var与不加var的区别
Dec 22 Javascript
JavaScript实现穷举排列(permutation)算法谜题解答
Dec 29 Javascript
AngularJS仿苹果滑屏删除控件
Jan 18 Javascript
jQuery获取table行数并输出单元格内容的实现方法
Jun 30 Javascript
JavaScript中的await/async的作用和用法
Oct 31 Javascript
jQuery实现级联下拉框实战(5)
Feb 08 Javascript
jquery mobile实现可折叠的导航按钮
Mar 11 Javascript
javascript回调函数的概念理解与用法分析
May 27 Javascript
node+vue实现用户注册和头像上传的实例代码
Jul 20 Javascript
浅谈手写node可读流之流动模式
Jun 01 Javascript
vue element table 表格请求后台排序的方法
Sep 28 Javascript
JavaScript中callee和caller的区别与用法实例分析
Jun 28 Javascript
Node.js net模块功能及事件监听用法分析
Jan 05 #Javascript
JS无限级导航菜单实现方法
Jan 05 #Javascript
JSON字符串操作移除空串更改key/value的介绍
Jan 05 #Javascript
JavaScript常见事件对象与操作实例总结
Jan 05 #Javascript
JavaScript常见事件处理程序实例总结
Jan 05 #Javascript
JavaScript代码调试方法实例小结
Jan 05 #Javascript
JavaScript实现连连看连线算法
Jan 05 #Javascript
You might like
PHP入门教程之操作符与控制结构流程详解
2016/09/09 PHP
php json中文编码为null的解决办法
2016/12/14 PHP
Yii框架使用PHPExcel导出Excel文件的方法分析【改进版】
2019/07/24 PHP
七种PHP开发环境搭建工具
2020/06/28 PHP
通过代码实例解析PHP session工作原理
2020/12/11 PHP
jquery插件制作教程 txtHover
2012/08/17 Javascript
屏蔽网页右键复制和ctrl+c复制的js代码
2013/01/04 Javascript
iframe窗口高度自适应的又一个巧妙实现思路
2014/04/04 Javascript
关于Vue.js一些问题和思考学习笔记(1)
2016/12/02 Javascript
angular.js 路由及页面传参示例
2017/02/24 Javascript
详解vue-cli中的ESlint配置文件eslintrc.js
2017/09/25 Javascript
原生JS实现图片懒加载之页面性能优化
2019/04/26 Javascript
vue滚动固定顶部及修改样式的实例代码
2019/05/30 Javascript
Vue分页器实现原理详解
2019/06/28 Javascript
layui监听工具栏的实例(操作列表按钮)
2019/09/10 Javascript
JavaScript实现Tab标签页切换的最简便方式(4种)
2020/06/28 Javascript
vue3.0 项目搭建和使用流程
2021/03/04 Vue.js
[03:12]完美世界DOTA2联赛PWL DAY7集锦
2020/11/06 DOTA
python学习之编写查询ip程序
2016/02/27 Python
Python 文件处理注意事项总结
2017/04/10 Python
Python subprocess模块功能与常见用法实例详解
2018/06/28 Python
python读取txt文件中特定位置字符的方法
2018/12/24 Python
python3爬虫学习之数据存储txt的案例详解
2019/04/24 Python
python matplotlib库绘制散点图例题解析
2019/08/10 Python
解决python明明pip安装成功却找不到包的问题
2019/08/28 Python
logging level级别介绍
2020/02/21 Python
在python tkinter界面中添加按钮的实例
2020/03/04 Python
vue常用指令代码实例总结
2020/03/16 Python
css3实现蒙版弹幕功能
2019/06/18 HTML / CSS
希尔顿酒店中国网站:Hilton中国
2017/03/11 全球购物
Rossignol金鸡美国官网:始于1907年法国百年雪具品牌
2019/03/06 全球购物
武汉世纪畅想数字传播有限公司.NET笔试题
2014/07/22 面试题
OSPF有什么优点?为什么OSPF比RIP收敛快?
2013/02/13 面试题
公司出纳岗位职责
2013/12/07 职场文书
宪法宣传周工作方案
2014/05/26 职场文书
再谈python_tkinter弹出对话框创建
2022/03/20 Python