Node中流的概念
在学习node的过程中,对于流的概念一直不是很理解,通过查阅一些资料,现在将自己对流的一些理解进行总结一下。
一.流的理解
首先我们必须知道什么是流,很多书中只是提到使用流读写文件怎么怎么方便,却不提流到底是什么?在说流之前我们先说一下流数据:
流数据:就是字节数据,在应用程序中各种对象之间交换与传输数据的时候,总是先将该对象中所包含的数据转化为字节数据也就是流数据。再通过流的传输,到达目的对象后,再将流数据转化为该对象中可以使用的数据。
从上面可知,流就是用来传输流数据的,它是一种传输手段
流:在一个应用程序中,流是一组有序的,有起点和终点的字节数据(流数据)的传输手段
二.能够使用流的对象
从流的概念中我们可以知道流是用来传输流数据的,也就是说我们需要把其他的对象数据转化为流数据。
在Node中,使用了各种实现了stream.Readable接口的对象读取流。也就是说只有这些对象才能够读取流。
Node.js中可以读取数据流的对象,列表如下:
| 对象 | 描述 |
|---|---|
| fs.ReadStream | 用于读取文件 |
| http.IncomingMesage | 代表客户端请求或服务端响应 |
| net.Socket | 代表一个socket端口对象 |
| child.stdout | 用于创建子进程的标准输出流 |
| child.stderr | 用于创建子进程的标准错误输出流 |
| process.stdin | 用于创建进程的标准输入流 |
| Gzip | 用于实现数据压缩 |
上面这些读取数据的对象将会触发的事件
| 事件名 | 描述 |
|---|---|
| readable | 当可以从流中读取数据时触发 |
| data | 当读取到来自文件,客户端,服务器端等对象的新的数据时触发 |
| end | 代表一个socket端口对象 |
| child.stdout | 当读取完所有的事件时触发,该事件的触发意味着data事件将不再被触发 |
| err | 当读取数据的过程中产生错误时触发 |
| close | 当用于读取数据的对象被关闭时触发,并非所有用于读取流数据的对象都会触发该事件 |
上面这些读取数据的对象所拥有的方法
在对象读取流的过程中,对象还拥有一些方法,可以对流进行一些操作,比如指定编码,指定流的传输目的地等。列表如下:
| 方法名 | 描述 |
|---|---|
| read | 用于读取数据 |
| setEncoding | 用于指定用什么编码方式读取数据 |
| pause | 用于通知对象停止触发data事件 |
| resume | 用于通知对象恢复触发data事件 |
| pipe | 用于设置一个数据通道,然后取出所有流数据并将其输出到通道另一端所指向的目标对象中 |
| unpipe | 用于取消pipe设置的通道 |
接下来使用fs模块中的createReadStream方法创建一个将文件读取为流数据的ReadStream对象,介绍一下流数据的读取。示例代码如下:
const fs = require('fs');
let file = fs.createReadStream('./data.txt');
// console.log(file); //得到的是一个ReadStream对象
//对象在读取文件时,需要先打开文件,打开文件会触发open事件
file.on('open',function(fd){
console.log('开始读取文件');
// console.log(fd);
});
//对象触发data事件,读取数据
file.on('data',function(data){
console.log('读取到数据');
console.log(data.toString());
});
//读取文件完毕,触发end事件
file.on('end',function(){
console.log('文件读取完毕');
});
//关闭文件,触发close事件
file.on('close',function(){
console.log('关闭文件')
});
file.on('error',function(err){
console.log(err)
});
上面介绍了Node.js中用于读取流的对象,以及在读取过程中,对象可能触发的事件以及调用的方法。下面介绍Node.js中用于写入流的对象,以及在写入过程中,这些对象可能触发的事件和调用的方法。
在Node.js中,使用各种实现了stream.Writable接口的对象来将流数据写入到对象中,所有这些对象都是继承了EventEmitter类的实例,在写入数据的过程中,将可能触发各种事件
各种用于写入流数据的对象,如下表所示:
| 对象 | 描述 |
|---|---|
| fs.WriteStream | 用于写入文件 |
| http.ClientRequest | 用于写入http客户端请求数据 |
| http.ServerResponse | 用于写入http服务端响应数据 |
| net.Socket | 代表一个socket端口对象 |
| child.stdin | 用于创建子进程的标准输入流 |
| process.stderr | 用于创建进程的标准错误输出流 |
| process.stdout | 用于创建进程的标准输出流 |
| Gunzip | 用于解压数据 |
这些对象将有可能触发的事件如下表所示:
| 事件名 | 描述 |
|---|---|
| drain | 当用于写入数据的write方法返回false之后触发 |
| finish | 当end方法被调用且数据被全部写入操作系统缓存区时触发 |
| pipe | 当用于读取数据的pipe方法被调用时触发 |
| unpipe | 当用于读取数据的pipe方法被调用时触发 |
| error | 当写入数据的过程中产生错误时触发 |
这些对象在写入数据的过程中,所拥有的方法如下表所示:
| 方法名 | 描述 |
|---|---|
| write | 用于写入有数据 |
| end | 当没有数据再被写入流中时调用该方法,这将迫使操作系统缓存区中的剩余 |
使用fs模块的createWriteStream方法创建一个将流数据写入文件的WriteStream对象。
const fs = require('fs');
let file = fs.createWriteStream('./result.txt');
file.write('hello Node.js',function(){
console.log('写入文件')
})
Node中流的概念的更多相关文章
- Node.js回调概念
什么是回调? 回调是一个异步等效的功能.在完成特定任务回调函数被调用. Node大量使用了回调.Node的所有的API都支持回调这样的一种方式. 例如,一个函数读取一个文件可能开始读取文件,并使得下一 ...
- 《精通并发与Netty》学习笔记(09 - Java中流的概念)
Java中流的概念 java程序通过流来完成输入/输出.流是生产或消费信息的抽象.流通过java的输入/输出与物理设备链接.尽管与它们链接的物理设备不尽相同,所有流的行为具有同样的方式.这样,相同的输 ...
- Node.js的概念与应用
转:http://blog.jobbole.com/100058/?utm_source=blog.jobbole.com&utm_medium=relatedPosts Node.js 是什 ...
- node.js基本概念简单解释
1:什么是回调函数? 2:什么是同步异步 3:什么是I/O 4:什么是单线程/多线程 5:什么是阻塞/非阻塞 6:什么是事件 7:什么是事件驱动 8:什么是事件驱动的回调 9:什么是事件循环 解释: ...
- node(1) npm是什么?node的异步概念
NPM是随同的NodeJS一起安装的包管理工具 他可以做什么? 1.可以从NPM服务器下载别人的东西使用 2.可以把自己的东西传到NPM服务器,让别人下载使用 淘宝的镜像会快一点 cnpm ...
- node开发基础概念
1.以严格模式运行一个js文件 node --use_strict xxx.js 2.退出node交互模式 连续按两次Ctrl+C. 3,node.js的模块不支持ES6的export.import规 ...
- Java中流的概念
http://wapwenku.baidu.com/view/04714847b307e87101f69656.html?ssid=0&from=1086k&uid=0&pu= ...
- 回忆一下Node(随时更改,想到什么写什么)
什么是Node? Node.js 是一个基于Chrome V8 引擎的JavaScript运行环境 Node.js使用了一个事件驱动.非阻塞式I/O的模型,使其轻量又高效 事件驱动: 任务执行,发布者 ...
- Node.js 教程 05 - EventEmitter(事件监听/发射器 )
目录: 前言 Node.js事件驱动介绍 Node.js事件 注册并发射自定义Node.js事件 EventEmitter介绍 EventEmitter常用的API error事件 继承EventEm ...
随机推荐
- 推荐Python、Django中文文档地址
协作翻译网:http://usyiyi.cn/ 老牌的Python中文社区:http://woodpecker.org.cn/ The Django Book2.0中文版:http://djangob ...
- Nginx 怎么给一台服务器,配置两个域名?详细的解说+截图教程
一. 环境.条件准备 一台云服务器(我的是腾讯的centos7) 至少两个域名.(我的是simuhunluo.xyz和simuhunluo.top.这两个域名之间没有任何关系,我是在阿里 ...
- There is No Alternative~最小生成树变形
Description ICPC (Isles of Coral Park City) consist of several beautiful islands. The citizens reque ...
- Spring+Redis的部署与Redis缓存使用示例
由于项目的业务需要,这两天折腾了一下Spring-redis配置,有了前面用Spring托管hibernate的经验,这次可以说是顺风顺水,大概说一下流程. ubuntu 安装 redis sudo ...
- asp.net 六大对象之Request、Response
ASP.NET的六大对象,本质上只是 Context 里面的属性,严格上不是对象. 1.Request-->读取客户端在Web请求期间发送的值 2.Response-->封装了页面执行期后 ...
- jieba库词频统计练习
在sypder上运行jieba库的代码: import matplotlib.pyplot as pltfracs = [2,2,1,1,1]labels = 'houqin', 'jiemian', ...
- 2、前端学习笔记之——css
<!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8&quo ...
- mysql 和 oracle 的一些小知识
有很多应用项目, 刚起步的时候用MYSQL数据库基本上能实现各种功能需求,随着应用用户的增多,数据量的增加,MYSQL渐渐地出现不堪重负的情况:连接很慢甚至宕机,于是就有把数据从MYSQL迁到ORAC ...
- C#实现联通短信Sgip协议程序源码
此程序为中国联通Sgip协议程序接口,适合在中国联通申请了短信发送端口的公司使用. 短信群发已经成为现在软件系统.网络营销等必不可少的应用工具.可应用在短信验证.信息群发.游戏虚拟商品购买.事件提醒. ...
- spring boot sso
https://hellokoding.com/hello-single-sign-on-sso-with-json-web-token-jwt-spring-boot/ https://github ...