本文为阅读朴灵大大的《深入浅出node.js》笔记:

  在前端开发的时候,我们不曾用过buffer,也没得用。buffer是node环境引入的,用来方便应对二进制数据的处理。这里我们对它应该有基础的理解和正确的定位,方能更好的使用它。

1、buffer不属于v8包含的内容

  buffer是node通过c++实现的,跟其他的一些核心模块类似,并不是说修改v8使,在v8中实现这个功能。

2、buffer不需要require

  我们在使用例如文件模块等等的模块都需要require来引入对应的模块,但buffer不需要,主要原因是因为它太常见了,所以在加载的时候,系统默认就把buffer加载到global上的Buffer上了,所以无需require就可以直接使用它。

3、buffer中用来存储数据的内存不属于v8,不受v8内存限制影响

  buffer占用内存分两部分,一部分是buffer对象,一部分的用来存储数据的pool。new出来的buffer对象是属于v8内存的一个对象,与v8的其它变量一样都满足自动垃圾回收的机制。而用来存储数据的pool是由c++直接向系统申请内存来存储的,有自己的内存处理机制。所以buffer数据存储的内存是数据v8之外,不会受到v8的最大内存限制的问题影响。对应的buffer对象会存放pool所在的位置信息和大小信息。

4、buffer和字符串可以很方便的互相转换,但是他们是不同的

  a)buffer也有length,但buffer的长度主要跟数据具体存储的字节数相关,而字符串却跟对应编码有关。

  b)因为buffer实际上跟对应编码是没有直接关系,所以,你甚至可以在一个buffer里面存储多种编码的内容,只要你能按存放的位置取出对应的内容即可。

  c)平常的数据流操作的时候,使用的其实都是buffer,方便数据的二进制传输,而字符串主要是引擎中字符串操作时使用的。

buffer常见处理技巧:

1、我们经常在读取一个数据流的情况下用chunks+=chunk的形式来把数据流data事件返回的信息拼接在一起:

var rs=createReadStream();
var chunks='';
rs.on('data',function(chunk){
chunks+=chunk;
});
rs.on('end',function(){
console.log(chunks);
});

这里主要的问题在于,data事件传入的chunk实际上是一个buffer数据,他的内容可能是截断的,并不是一个完整的字符串,而后面使用了

chunks+=chunk,实际上是把buffer转为字符串再拼接。这里如果是被截断的buffer就可能导致无法正常识别为字符串,展示为乱码。

所以这里应该使用buffer直接拼接为完成的buffer的形式来解决。

var rs=createReadStream();
var chunks=[];
rs.on('data',function(chunk){
chunks.push(chunk);
});
rs.on('end',function(){
console.log(Buffer.concat(chunks));
});

2、我们可能会有一个很长的字符串,需要在每次用户请求时返回给用户,如:

var longStr='';
for(var i=0;i<10*1024;i++){
longStr+='a';
}
//longStr=new Buffer(longStr);
http.createServer(function(req,res){
res.writeHead(200);
res.end(longStr);
});

这种情况下的问题就在于,每次请求调用res.end的时候,都是需要做一次操作等价longStr=new Buffer(longStr);比较浪费cpu,

所以这里应该把这一步的动作提前。把代码中的注释去掉,这样,我们就会把原来的longStr直接存储为Buffer,后续都可以直接使用,不浪费cpu。

本文为阅读朴灵大大《深入浅出node.js》的读书笔记

node.js中buffer需要知道的一些点的更多相关文章

  1. node.js中Buffer缓冲器的使用

    一.什么是Buffer Buffer缓冲器是用来存储输入和输出数据的一段内存.js语言没有二进制数据类型,在处理TCP和文件流的时候,就不是很方便了. 所以node.js提供了Buffer类来处理二进 ...

  2. 学废了系列 - WebGL与Node.js中的Buffer

    WebGL 和 Node.js 中都有 Buffer 的使用,简单对比记录一下两个完全不相干的领域中 Buffer 异同,加强记忆. Buffer 是用来存储二进制数据的「缓冲区」,其本身的定义和用途 ...

  3. Node.js学习 - Buffer

    JavaScript 语言自身只有字符串数据类型,没有二进制数据类型.但在处理像TCP流或文件流时,必须使用到二进制数据. 因此在 Node.js中,定义了一个 Buffer 类,该类用来创建一个专门 ...

  4. 在Node.js中使用RabbitMQ系列二 任务队列

    在上一篇文章在Node.js中使用RabbitMQ系列一 Hello world我有使用一个任务队列,不过当时的场景是将消息发送给一个消费者,本篇文章我将讨论有多个消费者的场景. 其实,任务队列最核心 ...

  5. node.js中process进程的概念和child_process子进程模块的使用

    进程,你可以把它理解成一个正在运行的程序.node.js中每个应用程序都是进程类的实例对象. node.js中有一个 process 全局对象,通过它我们可以获取,运行该程序的用户,环境变量等信息. ...

  6. node.js中使用http模块创建服务器和客户端

    node.js中的 http 模块提供了创建服务器和客户端的方法,http 全称是超文本传输协议,基于 tcp 之上,属于应用层协议. 一.创建http服务器 const http = require ...

  7. node.js中通过dgram数据报模块创建UDP服务器和客户端

    node.js中 dgram 模块提供了udp数据包的socket实现,可以方便的创建udp服务器和客户端. 一.创建UDP服务器和客户端 服务端: const dgram = require('dg ...

  8. node.js中stream流中可读流和可写流的使用

    node.js中的流 stream 是处理流式数据的抽象接口.node.js 提供了很多流对象,像http中的request和response,和 process.stdout 都是流的实例. 流可以 ...

  9. node.js中fs文件系统模块的使用

    node.js中为我们提供了fs文件系统模块,实现对文件或目录的创建,修改和删除等操作. fs模块中,所有的方法分为同步和异步两种实现. 有 sync 后缀的方法为同步方法,没有 sync 后缀的方法 ...

随机推荐

  1. python之路3:

    class set(object): """ set() -> new empty set object set(iterable) -> new set o ...

  2. SQL数据库中字段类型 与C#中的对应字段类型

    数据库中的字段类型和对应的C#中的对应字段类型 数据库                 C#程序int int32text stringbigint int64binary System.Byte[] ...

  3. 如何将推送证书p12导出为pem

    1. 在Mac上启动Keychain助手,然后在login keychain中选择 Certificates分类.你将看到一个可展开的“Apple Development Push Services” ...

  4. C#文件创建、修改、访问时间修改

    using System; using System.Collections.Generic; using System.ComponentModel; using System.Data; usin ...

  5. 规则“Windows Server 2003 FILESTREAM 修补程序检查” 失败。

    近期在客户环境搭建SQL故障转移群集,操作系统为SQL Server 2012R2,数据库版本为SQL Server2008 R2,在安装过程中遇到问题:没有安装Windows Server 2003 ...

  6. i.

    史上最全web.xml配置文件元素详解 一.web.xml配置文件常用元素及其意义预览 <!--servlet API的版本2.3增加了对事件监听程序的支持,事件监听程序在建立.修改和删除会话或 ...

  7. centos6.5安装node.js

    一次偶然的机会知道有nodejs这个东西,确实对它还是很感兴趣的.刚开始只知道它能让javascript写后台,然后前后台都由javascript来写,确实觉得真的挺爽,毕竟人总是喜欢在自己熟悉领域做 ...

  8. Result Maps collection already contains value for

    Result Maps collection already contains value for select s.id,s.branch_name from t_wx_shop s left jo ...

  9. ps

    快速恢复默认值  有些不擅长Photoshop的朋友为了调整出满意的效果真是几经周折,结果发现还是原来的默认效果最好,这下傻了眼,后悔不该当初呀!怎么恢复到默认值呀?试着轻轻点按选项栏上的工具图标,然 ...

  10. 点击按钮div显示,点击div或者document,div隐藏

    $("button").click(function(event){ event.stopPropagation(); if($("div").is(':hid ...