zoukankan      html  css  js  c++  java
  • nodejs基础 -- Stream流

    nodejs 的 Stream 是一个抽象接口,node中有很多对象实现了这个接口。例如,对http服务器发起请求的request对象就是一个Stream,还有stdout(标准输出)也是一个Stream

    nodejs中 Stream 有四种流类型

    Readable:可读操作

    Writable:可写操作

    Duplex:可读可写操作

    Transform:操作被写入数据,然后读出结果

    nodejs 中所有 Stream 对象都是EventEmitter的实例。常用的事件由:

    data:当有数据可读时触发

    end:没有更多的数据可读时触发

    error:在接收和写入过程中发生错误的时候触发

    finish:所有数据已被写入到底层系统的时候触发

    从流中读取数据

    创建input.txt文件,内容如下:谷歌网址:www.google.com

    创建stream.js文件,代码如下:

    var fs = require("fs");
    var data = '';
    
    // 创建可读流
    var readerStream = fs.createReadStream('input.txt');
    
    // 设置编码为 utf8。
    readerStream.setEncoding('UTF8');
    
    // 处理流事件 --> data, end, and error
    readerStream.on('data', function(chunk) {
       data += chunk; //读取过程中触发
    });
    
    readerStream.on('end',function(){
       console.log(data); //读取完成后触发
    });
    
    readerStream.on('error', function(err){
       console.log(err.stack); //读取出错时触发(如input.txt文件不存在)
    });
    
    console.log("程序执行完毕");

    结果:

    程序执行完毕
    谷歌网址:www.google.com

    写入流

    var fs = require("fs");
    var data = '菜鸟教程官网地址:www.runoob.com';
    
    // 创建一个可以写入的流,写入到文件 output.txt 中
    var writerStream = fs.createWriteStream('output.txt');
    
    // 使用 utf8 编码写入数据
    writerStream.write(data,'UTF8');
    
    // 标记文件末尾
    writerStream.end();
    
    // 处理流事件 --> data, end, and error
    writerStream.on('finish', function() {
        console.log("写入完成。");
    });
    
    writerStream.on('error', function(err){
       console.log(err.stack);
    });
    
    console.log("程序执行完毕");

    结果:

    程序执行完毕
    写入完成。

    查看 output.txt 文件的内容:

    菜鸟教程官网地址:www.runoob.com

    管道流

    管道提供了一个输出流到输入流的机制。通常我们用于从一个流中获取数据并将数据传递到另外一个流中。

    这样就慢慢的实现了大文件的复制过程。

    var fs = require("fs");
    
    // 创建一个可读流
    var readerStream = fs.createReadStream('input.txt');
    
    // 创建一个可写流
    var writerStream = fs.createWriteStream('output.txt');
    
    // 管道读写操作
    // 读取 input.txt 文件内容,并将内容写入到 output.txt 文件中
    readerStream.pipe(writerStream);
    
    console.log("程序执行完毕");

    链式流

    链式是通过连接输出流到另外一个流并创建多个对个流操作链的机制。链式流一般用于管道操作。

    接下来我们就是用管道和链式来压缩解压文件。

    压缩:

    创建 compress.js 文件, 代码如下:

    var fs = require("fs");
    var zlib = require('zlib');
    
    // 压缩 input.txt 文件为 input.txt.gz
    fs.createReadStream('input.txt')
      .pipe(zlib.createGzip())
      .pipe(fs.createWriteStream('input.txt.gz'));
      
    console.log("文件压缩完成。");

    代码执行结果如下:

    $ node compress.js 
    文件压缩完成。

    执行完以上操作后,我们可以看到当前目录下生成了 input.txt 的压缩文件 input.txt.gz

    解压

    接下来,让我们来解压该文件,创建 decompress.js 文件,代码如下:

    var fs = require("fs");
    var zlib = require('zlib');
    
    // 解压 input.txt.gz 文件为 input.txt
    fs.createReadStream('input.txt.gz')
      .pipe(zlib.createGunzip())
      .pipe(fs.createWriteStream('input.txt'));
      
    console.log("文件解压完成。");

    代码执行结果如下:

    $ node decompress.js 
    文件解压完成。
  • 相关阅读:
    白兔的字符串(字符串hash+模拟map)
    [TJOI2013]单词(AC自动机+前缀和维护)
    [SDOI2014]数数(ac自动机+数位DP)
    阿狸的打字机(AC自动机+dfs序 + 维护区间值)
    string(AC自动机 在线询问转离线询问)
    E
    JMX超详细解读
    快速生成100万数据人员信息数据
    聊聊spring之bean对象的实例化过程
    聊聊spring之贯穿全局的重要对象BeanDefinition
  • 原文地址:https://www.cnblogs.com/hf8051/p/5054273.html
Copyright © 2011-2022 走看看