美文网首页
谈谈node中流的理解

谈谈node中流的理解

作者: 时光与少年已陈旧 | 来源:发表于2018-02-03 22:36 被阅读0次

node中Stream分为Readable(可读流)、Writable(可写流)、Duplex(可读写流)、Transform(读写过程中可以修改和变换数据的 Duplex 流)。

为了实现可写流,我们需要使用流模块中的Writable构造函数。 我们只需给Writable构造函数传递一些选项并创建一个对象。唯一需要的选项是write函数,该函数揭露数据块要往哪里写。

chunk通常是一个buffer,除非我们配置不同的流。

encoding是在特定情况下需要的参数,通常我们可以忽略它。

callback是在完成处理数据块后需要调用的函数。这是写数据成功与否的标志。若要发出故障信号,请用错误对象调用回调函数

下面代码用ES6对可写流进行代码简要的实现:

let fs = require('fs');

let EventEmitter = require('events');

class WriteStream extends EventEmitter {

constructor(path, options) {

super();

let self = this;

Object.assign(self, options); //还需设置默认值

self.path = path; //文件路经

self.isWriting = false;

self.Buffer = []; //缓冲区

self.len = null;

self.pos = self.start; //初始化写入位置

self.fd = null;

self.open();

}

open() {//首先打开文件

let self = this;

fs.open(self.path, self.flags, self.mode, (err, fd) => {

self.fd = fd;

if (err) return self.destroy(err);

self.emit('open');

});

}

destroy(err) {

fs.close(this.fd, () => {

this.emit('error', err);

});

}

write(chunk, encoding, cb) {

let self = this

, ret = null;

encoding = encoding?encoding:self.encoding; //优先使用write传入的编码方式

chunk = Buffer.isBuffer(chunk) ? chunk : Buffer.from(chunk, encoding);

self.len += chunk.length;

ret = self.highWaterMark > self.len; //判断当前最新的缓冲区是否已达到最高水位线

if (self.isWriting) { //说明正在调用底层方法真正写入文件,先写入Buffer

self.Buffer.push({

chunk

, cb

});

} else {

self.isWriting = true;

self._write(chunk, cb, () => self.clearBuffer());

}

return ret;

}

_write(chunk, cb, clear) {

let self = this;

if (!self.fd) return self.once('open', () => {

self._write(chunk, cb, clear)

});

fs.write(self.fd, chunk, 0, chunk.length, self.pos, (err, bytesWritten) => {

if (err) {

if (self.autoClose) {

self.destroy();

self.emit('error', err);

}

}

self.len -= bytesWritten;

self.pos += bytesWritten;

cb && cb();

clear && clear();

});

}

clearBuffer() {

let self = this

, data = null;

data = self.Buffer.shift();

if (data) {

self._write(data.chunk, data.cb, () => self.clearBuffer());

} else { //此时说明缓冲区已无数据

self.isWriting = false;

self.emit('drain');

}

}

}

相关文章

  • 谈谈node中流的理解

    node中Stream分为Readable(可读流)、Writable(可写流)、Duplex(可读写流)、Tra...

  • 理解Node中流的概念

    在学习node的过程中,对于流的概念一直不是很理解,通过查阅一些资料,现在将自己对流的一些理解进行总结一下。 一....

  • 谈谈我对node特点的理解

    打开node官网,可以看到首页正中写着: Node.js® is a JavaScript runtime bui...

  • 对nodejs中流的理解

    一,为什么需要流? 当我们学习一个东西的时候,首先我们要知道为什么要学习?那我们为什么要使用流呢?在node中读取...

  • Java进阶struts & Hibernate面试题(8)

    【71】谈谈你对Struts的理解。 【72】谈谈你对Hibernate的理解。 【72】谈谈你对Spring的理...

  • 面试积累之框架(五)

    谈谈你对AOP的理解: 谈谈对sprin的理解 SpringMVC的工作机制

  • 理解node

    本文理解于understanding node.js node app里面除了你自己以外的所有代码都是并行执行的,...

  • node理解

  • Texture

    基本概念介绍Node: Texture的基本单元是Node,Node可以理解为UIKit的UIView(Node是...

  • 深入nodejs中流(stream)的理解

    流的基本概念及理解 流是一种数据传输手段,是有顺序的,有起点和终点,比如你要把数据从一个地方传到另外一个地方流非常...

网友评论

      本文标题:谈谈node中流的理解

      本文链接:https://www.haomeiwen.com/subject/bmdpzxtx.html