node.js中的buffer.slice方法使用说明


Posted in Javascript onDecember 10, 2014

方法说明:

返回一个新的buffer对象,这个新buffer和老buffer公用一个内存。

但是被start和end索引偏移缩减了。(比如,一个buffer里有1到10个字节,我们只想要4-8个字节,就可以用这个函数buf.slice(4,8),因为他们共用一个内存,所以不会消耗内存,)

因为共用内存,所以修改新的buffer后,老buffer的内容同样也会被修改。

语法:

buffer.slice([start], [end])

接收参数:

start      开始位置,默认

end      结束位置,默认为buffer长度

例子:

用ASCII码字母表创建一个buffer,用一下slice函数,然后修改原buffer中的一个字节。

var buf1 = new Buffer(26);

for (var i = 0 ; i < 26 ; i++) {

  buf1[i] = i + 97; // 97 is ASCII a

}

var buf2 = buf1.slice(0, 3);

console.log(buf2.toString('ascii', 0, buf2.length));

buf1[0] = 33;

console.log(buf2.toString('ascii', 0, buf2.length));

// abc

// !bc

源码:

// TODO(trevnorris): currently works like Array.prototype.slice(), which

// doesn't follow the new standard for throwing on out of range indexes.

Buffer.prototype.slice = function(start, end) {

  var len = this.length;

  start = ~~start;

  end = util.isUndefined(end) ? len : ~~end;

  if (start < 0) {

    start += len;

    if (start < 0)

      start = 0;

  } else if (start > len) {

    start = len;

  }

  if (end < 0) {

    end += len;

    if (end < 0)

      end = 0;

  } else if (end > len) {

    end = len;

  }

  if (end < start)

    end = start;

  var buf = new NativeBuffer();

  sliceOnto(this, buf, start, end);

  buf.length = end - start;

  if (buf.length > 0)

    buf.parent = util.isUndefined(this.parent) ? this : this.parent;

  return buf;

};
Javascript 相关文章推荐
读jQuery之一(对象的组成)
Jun 11 Javascript
读jQuery之二(两种扩展)
Jun 11 Javascript
jQuery+CSS 实现随滚动条增减的汽水瓶中的液体效果
Sep 26 Javascript
jquery触发a标签跳转事件示例代码
Jul 21 Javascript
html5+javascript制作简易画板附图
Apr 25 Javascript
Javascript函数的参数
Jul 16 Javascript
JavaScript编写带旋转+线条干扰的验证码脚本实例
May 30 Javascript
jQuery post数据至ashx实例详解
Nov 18 Javascript
详细AngularJs4的图片剪裁组件的实例
Jul 12 Javascript
vue中render函数的使用详解
Oct 12 Javascript
vue - props 声明数组和对象操作
Jul 30 Javascript
一文秒懂JavaScript构造函数、实例、原型对象以及原型链
Aug 25 Javascript
node.js中的buffer.write方法使用说明
Dec 10 #Javascript
node.js中的http.request.end方法使用说明
Dec 10 #Javascript
node.js中的emitter.on方法使用说明
Dec 10 #Javascript
node.js中的events.emitter.once方法使用说明
Dec 10 #Javascript
node.js中的emitter.emit方法使用说明
Dec 10 #Javascript
node.js中的events.emitter.removeListener方法使用说明
Dec 10 #Javascript
node.js中的events.emitter.listeners方法使用说明
Dec 10 #Javascript
You might like
《星际争霸重制版》兵种对比图鉴
2020/03/02 星际争霸
《DOTA3》开发工作已经开始 《DOTA3》将代替《DOTA2》
2021/03/06 DOTA
PHP CLI模式下的多进程应用分析
2013/06/03 PHP
输入值/表单提交参数过滤有效防止sql注入的方法
2013/12/25 PHP
PHP四舍五入精确小数位及取整
2014/01/14 PHP
ThinkPHP自动填充实现无限级分类的方法
2014/08/22 PHP
转自Jquery官方 jQuery1.1.3发布,速度提升800%,体积保持20K
2007/08/19 Javascript
javascrip客户端验证文件大小及文件类型并重置上传
2011/01/12 Javascript
js查错流程归纳
2012/05/04 Javascript
jQuery实现瀑布流布局详解(PC和移动端)
2020/09/01 Javascript
3kb jQuery代码搞定各种树形选择的实现方法
2016/06/10 Javascript
nodejs批量下载图片的实现方法
2017/05/19 NodeJs
微信小程序之自定义组件的实现代码(附源码)
2018/08/02 Javascript
Vue框架里使用Swiper的方法示例
2018/09/20 Javascript
vue 中基于html5 drag drap的拖放效果案例分析
2018/11/01 Javascript
详解如何使用微信小程序云函数发送短信验证码
2019/03/13 Javascript
vue App.vue中的公共组件改变值触发其他组件或.vue页面监听
2019/05/31 Javascript
JavaScript实现单英文金山打字通
2020/07/24 Javascript
Python使用urllib2获取网络资源实例讲解
2013/12/02 Python
Python批量转换文件编码格式
2015/05/17 Python
通过Python爬虫代理IP快速增加博客阅读量
2016/12/14 Python
Pycharm无法显示动态图片的解决方法
2018/10/28 Python
我用Python抓取了7000 多本电子书案例详解
2019/03/25 Python
Python爬虫使用代理IP的实现
2019/10/27 Python
python 串口读取+存储+输出处理实例
2019/12/26 Python
pytorch 指定gpu训练与多gpu并行训练示例
2019/12/31 Python
利用Python如何实时检测自身内存占用
2020/05/09 Python
Python如何对齐字符串
2020/07/30 Python
英国领先的互联网葡萄酒礼品商:Vintage Wine & Port
2019/05/24 全球购物
求职信内容考虑哪几点
2013/10/05 职场文书
期末总结的个人自我评价
2013/11/02 职场文书
手机业务员岗位职责
2013/12/13 职场文书
环境建议书
2015/02/04 职场文书
交通安全教育心得体会
2016/01/15 职场文书
Java实现多线程聊天室
2021/06/26 Java/Android
详解Vue中$props、$attrs和$listeners的使用方法
2022/02/18 Vue.js