node.js Stream Buffer FsPromise
Stream:
类似这样:a.pipe(b).pipe(c); 我想写一个b。所以:
var rs=new (require('stream').Readable)();
var ws=new (require('stream').Writable)(); rs._read=function(){
this.push('send a msn for the first time');
this.push('send a msn for the second time');
this.push(null);
} ws._wirte=function(chunk,encoding,next){
console.log(chunk.toString());
next()
} var Duplex=function(){
let duplex= new (require('stream').Duplex)();
duplex._read=function(){
this.push(null);
}
duplex._write=function(chunk,e,callback){
this.push(chunk.toString()+'...by ztw');
next()
}
return duplex;
}
var myDuplex=Duplex(); rs.pipe(myDuplex).pipe(ws);
最后正常显示:
Buffer:
先说概念:
Unicode定义码点,utf8配置字节如何对应码点。
Buffer,你能看到是Unicode 16进制码的形式储存。
Buffer[0],这种返回的是10进制的Unicode码,这和'string'.charCodeAt(0)是一样的。
JS对4字节的Unicode码支持不好,'string'.length不对。使用:[...'string'].length。
var buffer=new Buffer('Buffer Test','utf8'); buffer.toString('utf8',0,4); // 'Buff' 位置按buffer内的位置算,非String的位置。 buffer.copy(buffer2, targetStart, sourceStart, sourceEnd) ;
// 说形象点,按照[sourceStart,sourceEnd]对buffer进行裁剪,并从buffer2的targetStart位置,开始替换。 buffer.fill('shit' , sourceStart, sourceEnd );
//使用shit在buffer的裁剪区域进行填充,填充方式为:repeat; buffer.fill('shit') //全部填充 buffer.write('strawberry', start,end); //替换某个位置。 Buffer.concat([buf1,buf2]); //合并两个Buffer;
详见官方API;
JS中有原生的buffer支持,ArrayBuffer,举个例子:
var arryBuffer=new ArrayBuffer(10); //Buffer,拥有10个字节的容量。
var arr1=new Int8Array(arryBuffer);
//每个Int8Array(Unit8Array...)都带有一个ArrayBuffer。这里显示申明了而已。我们可以这样获得它: var buf=arr1.buffer; //buf指向arryBuffer,两者是一样的。 var arr2=new Int8Array(buf) ; //arr2与arr1使用同一空间,二者关联,值也相同。
var arr2=new Int8Array(buf.slice(5)); //只将5以后的空间分配给arr2,而arr1仍然全部占有。
new Buffer(buf) //可以得到这个Buffer。只能在nodeJs端使用。 buf.typeLength // 返回buf的字节容量大小。
FsPromise:
nodeJS没有提供FS的promise模块,需要自己包装:
function fsPromise(method){
return function(...args){
return new Promise((resolve,reject)=>{
method.apply(method,args.concat([(err,data)=>{resolve(data)}]))
})
}
}
写一个最简单直接的,其他功能可以在这基础上变通。
最后使用:
fsPromise(fs.readFile)('fileName','utf8').then(val=>console.log(val));
FsPromise为了跳出callBack的嵌套。还可以这样:
function thunkify(method){
return function(){
return function(...args){
return function(fn){
method(...args,fn); //相同于 method.apply(method, args.concat[fn]);
};
}
}
}
先想定义一个thunkify;再接着写:
var readFile=thunkify(fs.readFile);
var FsGen=function* (){
yield readFile('fileOne','utf8');
yield readFile('fileTwo','utf8');
} var fg=FsGen();
nextFile(); //调用nextFile,按顺序异步读取文件。 function nextFile(err,data){
let result=fg.next();
data?console.log(data):0;
if(!result.done) result.value(nextFile);
}
同样跳出callback嵌套。而generators 配合thunkify函数,可以异步处理更多的文件。
使用thunkify,为了让readFile再返回一个function,并在其中执行fg.next()。如果在readFile中执行fg.next()。会返回Generators is aready running;
--------------------------来一个FsPromise的实例-----------------------------:
function toPromise(method){
return function(){
return functin(...args){
return new Promise((resolve,reject)=>{
method(...args,(...data)=>{
resolve(data); //把它小小升级一下,data为array型,以支持不同参型。
})
})
}
}
} process.stdin.setEncoding('utf8');
const stdinOnce=process.stdin.once.bind(process.stdin);//记得bind; toPromise(stdinOnce)('data').then(val=>{
process.stdout.write(...val);
console.log('step1');
return toPromise(stdinOnce)('data');
})
.then(val=>{
process.stdout.write(...val);
console.log('step2');
return toPromise(stdinOnce)('data');
})
.then(val=>{
console.log('end');
process.stdout.end();
})
实现一个,按步骤根据用户输入就来进行回应的,大致框架。
因为fs.readFile本身是一个obj,所以可以直接toPromise(fs.readFile)。
而process.stdin.one是一个方法,直接另名为stdinOnce,会丢失内部的this。
而使用method.call(process.stdin),也不可取。
所以:
const stdinOnce=process.stdin.once.bind(process.stdin);
node.js Stream Buffer FsPromise的更多相关文章
- 9、Node.js Stream(流)
#########################################################################介绍Node.js Stream(流)Stream 是 ...
- 笔记:Node.js 的 Buffer 缓冲区
笔记:Node.js 的 Buffer 缓冲区 node.js 6.0 之前创建的 Buffer 对象使用 new Buffer() 构造函数来创建对象实例,但权限很大,可以获得敏感信息,所以建议使用 ...
- [Node.js] 03 - Buffer, Stream and File IO
fs 模块,视频教学 os 模块,视频教学,api doc Buffer类 创建 Buffer 类 // 创建一个长度为 10.且用 0 填充的 Buffer. const buf1 = Buffer ...
- Node.js:Buffer浅谈
Javascript在客户端对于unicode编码的数据操作支持非常友好,但是对二进制数据的处理就不尽人意.Node.js为了能够处理二进制数据或非unicode编码的数据,便设计了Buffer类,该 ...
- [Node.js] Stream all things!
Node.js come alone with many Stream API. Stream is useful when handling large trunck of data. For ex ...
- node.js中buffer需要知道的一些点
本文为阅读朴灵大大的<深入浅出node.js>笔记: 在前端开发的时候,我们不曾用过buffer,也没得用.buffer是node环境引入的,用来方便应对二进制数据的处理.这里我们对它应该 ...
- Node.js stream 流学习
由于node.js 创建http 是这样的 http.createServer(function(request,response){}).listen(2000); 里面的request 就是rea ...
- Node.js学习 - Buffer
JavaScript 语言自身只有字符串数据类型,没有二进制数据类型.但在处理像TCP流或文件流时,必须使用到二进制数据. 因此在 Node.js中,定义了一个 Buffer 类,该类用来创建一个专门 ...
- Node.js Stream(流)
Stream 是一个抽象接口,Node 中有很多对象实现了这个接口.例如,对http 服务器发起请求的request 对象就是一个 Stream,还有stdout(标准输出). Node.js,Str ...
随机推荐
- ueditor工具栏更改按钮的默认操作
ueditor 上的 image 按钮,默认有一个图片选择工具. 但是我想把他去掉,用上自己写的图片选择功能. 原来使用cleditor 是可以给按钮自定义一个函数.但是在ueditor就没有找到可以 ...
- Python/dotNET Redis服务连接客户端调用SET方法的同时获取Redis服务器返回的内容
在用Python或dotNET redis客户端连接redis服务器的时候,当你调用客户端的SET方法后同时还想得到其返回的字符串,那么需要处理一下. 1. Redis Python redis客户端 ...
- Maven联网问题
关于Maven联网问题 关于如何找到Maven默认的本地仓库问题 修改Maven默认本地仓库 找到 <localRepository>/path/to/local/repo</loc ...
- 常见ES6新属性
ES6是即将到来的新版本JavaScript语言的标准,他给我们带来了更"甜"的语法糖(一种语法,使得语言更容易理解和更具有可读性,也让我们编写代码更加简单快捷),如箭头函数(=& ...
- CIImage实现滤镜效果
Core Image also provides autoadjustment methods that analyze an image for common deficiencies and re ...
- 【转】 数据库系统——B+树索引
原文来自于:http://blog.csdn.net/cjfeii/article/details/10858721 1. B+树索引概述 在上一篇文章中,我们讨论了关于index的几个中重要的课题: ...
- html学习心得
注释:浏览器会自动地在段落的前后添加空行.(<p> 是块级元素) 提示:使用空的段落标记 <p></p> 去插入一个空行是个坏习惯.用 <br /> 标 ...
- 基于KNN的newsgroup 18828文本分类器的Python实现
还是同前一篇作为学习入门. 1. KNN算法描述: step1: 文本向量化表示,计算特征词的TF-IDF值 step2: 新文本到达后,根据特征词确定文本的向量 step3 : 在训练文本集中选出与 ...
- mybatis配置文件查询参数的传递
通常来说,参数传递可以使用#与$进行编写,但是使用#的效率更高,使用$方式,查看日志更方便些,尤其是当执行的sql语句非常麻烦的时候. 1) 接口 形式 以下方式 [传递参数是一个实体] public ...
- DotNetBar TabControl的使用
这个和系统的TabPage不同,一个TabPage分为了DevComponents.DotNetBar.TabItem,DevComponents.DotNetBar.TabControlPanel两 ...