JS在线运行

版本:
运行结果
教程手册
代码仓库
极速运行
终端运行
图形+终端

                        
以下是用户最新保存的代码
计数排序算法 发布于:2023-12-03 20:08 js计数排序 发布于:2023-12-03 15:13 使用js实现线性计数排序 发布于:2023-12-03 14:49 js实现计数排序 发布于:2023-12-03 14:39 计数排序的设计 发布于:2023-12-02 21:27 线性计数排序的设计 发布于:2023-12-02 21:18 某人准备跑20圈来锻炼自己的身体,他准备分多次(>1)跑完,每次都跑正整数圈,然后休息下再继续跑。 发布于:2023-12-03 11:36 输入一个由小写字母a-z以及左括号(和有括号)组成的字符串s,尽可能少的删除括号,使得字符串中的括号匹配,返回删除括号后的字符串。(输出不唯一) 发布于:2023-12-01 12:27 excel的图片处理JS 发布于:2023-12-01 10:20 括号匹配的增强版本,要求输出括号里的内容 发布于:2023-11-30 12:36 学习js的第二天 不知道代码有没有错 发布于:2023-11-29 20:33 学习代码的第二天 1. 自定义程序: -**gcd**(最大公因数) 发布于:2023-11-29 20:12 策略执行流程部分示例代码 发布于:2023-11-29 20:31 堆排序的实现 发布于:2023-11-27 22:36 在线人数显示 发布于:2023-11-26 11:46 初学者的呻吟! 发布于:2023-11-24 13:44 新共享员工工作量明细查询 发布于:2023-11-23 10:11 JS堆排序 发布于:2023-11-22 21:00 大根堆自顶向下 发布于:2023-11-22 21:20 交通信号灯 发布于:2023-11-21 09:12 第9章:交通信号灯实践 发布于:2023-11-21 09:20 时间 季姬击鸡记街机 发布于:2023-11-20 22:04 hello world 发布于:2023-11-20 13:00 hello world 发布于:2023-11-20 13:01 验证Promise.all嵌套Promsie.all的执行顺序 发布于:2023-11-17 16:41 测试运行结果 发布于:2023-11-16 18:21 浪潮PUT请求 发布于:2023-11-16 17:03 url参数 发布于:2023-11-15 11:06 无序数组中的第 K 大元素 发布于:2023-11-14 21:49 快速排序算法 发布于:2023-11-14 21:48 生成器函数 发布于:2023-11-14 20:49 查找一个无序数组中的第 K 大元素 发布于:2023-11-13 20:28 快速排序。 发布于:2023-11-13 20:26 一些常用方法 发布于:2023-11-13 17:36 快速选择排序求第几大数子 发布于:2023-11-12 11:09 快速排序算法 发布于:2023-11-12 10:33 实现数组去重 发布于:2023-11-09 21:53 实现数组的扁平化 发布于:2023-11-09 21:50 kuaipai 第k个 发布于:2023-11-09 17:05 不使用额外数组情况下,实现快速排序 发布于:2023-11-08 14:48 JS 打印过去30天的日期和星期 发布于:2023-11-07 19:57 JS 打印未来30天日期和星期 发布于:2023-11-07 19:55 js 原型 实战 发布于:2023-11-07 10:54 JS prototype 原型 发布于:2023-11-06 16:10 String相关处理函数 发布于:2023-11-06 14:51 求解无序数组中逆序对的个数 发布于:2023-11-06 14:29 归并排序算法 发布于:2023-11-06 14:21 手写apply和bind 发布于:2023-11-06 12:54 vue3源码解析 发布于:2023-11-06 16:16 Javascript数组相关函数 发布于:2023-11-06 11:05 [更多]
显示目录

Stream(流)



Node.js Stream(流)

Stream 是 Node.js 中非常重要的一个模块,应用广泛。

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

该抽象接口是可读、可写或是既可读又可写的,通过这些接口,我们可以和磁盘文件、套接字、HTTP请求来交互,实现数据从一个地方流动到另一个地方的功能。

Node.js,Stream 有四种流类型:

  • Readable - 可读操作。

  • Writable - 可写操作。

  • Duplex - 可读可写操作.

  • Transform - 操作被写入数据,然后读出结果。

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

  • data - 当有数据可读时触发。

  • end - 没有更多的数据可读时触发。

  • error - 在接收和写入过程中发生错误时触发。

  • finish - 所有数据已被写入到底层系统时触发。

本教程会为大家介绍常用的流操作。


从流中读取数据

创建 input.txt 文件,内容如下:

jsrun教程官网地址:jsrun.net

创建 main.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);
});

console.log("程序执行完毕");

以上代码执行结果如下:

程序执行完毕
jsrun教程官网地址:jsrun.net

写入流

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

var fs = require("fs");
var data = 'jsrun教程官网地址:jsrun.net';

// 创建一个可以写入的流,写入到文件 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("程序执行完毕");

以上程序会将 data 变量的数据写入到 output.txt 文件中。代码执行结果如下:

$ node main.js 
程序执行完毕
写入完成。

查看 output.txt 文件的内容:

$ cat output.txt 
jsrun教程官网地址:jsrun.net

管道流

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

如上面的图片所示,我们把文件比作装水的桶,而水就是文件里的内容,我们用一根管子(pipe)连接两个桶使得水从一个桶流入另一个桶,这样就慢慢的实现了大文件的复制过程。

以下实例我们通过读取一个文件内容并将内容写入到另外一个文件中。

设置 input.txt 文件内容如下:

jsrun教程官网地址:jsrun.net
管道流操作实例

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

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("程序执行完毕");

代码执行结果如下:

$ node main.js 
程序执行完毕

查看 output.txt 文件的内容:

$ cat output.txt 
jsrun教程官网地址:jsrun.net
管道流操作实例

链式流

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

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

创建 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 
文件解压完成。
由JSRUN为你提供的JS在线运行、在线编译工具
        JSRUN提供的JS 在线运行,JS 在线运行工具,基于linux操作系统环境提供线上编译和线上运行,具有运行快速,运行结果与常用开发、生产环境保持一致的特点。