当前位置: 首页> 新闻> 会展 > 苏州中心疫情_大型网站制作都有哪些_百度运营怎么做_网店代运营十大排名

苏州中心疫情_大型网站制作都有哪些_百度运营怎么做_网店代运营十大排名

时间:2025/9/13 6:41:54来源:https://blog.csdn.net/heming20122012/article/details/147124988 浏览次数:1次
苏州中心疫情_大型网站制作都有哪些_百度运营怎么做_网店代运营十大排名

1、参考:Node.js Stream(流) | 菜鸟教程

2.1、从流中读取数据

常见的可读流包括文件读取流和网络请求响应流。

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

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

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

以上代码执行结果如下:

程序执行完毕
菜鸟教程官网地址:www.runoob.com

2.2、写入流

可写流用于将数据写入目的地,常见的可写流包括文件写入流和网络请求发送流。

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

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

执行输出如下:

output.txt文件内容如下:

2.3、双工流(Duplex)

双工流同时具有可读和可写的能力。

一个典型的双工流是 TCP 套接字。

const net = require('net');// 创建一个 TCP 服务器
const server = net.createServer((socket) => {console.log('Client connected.');// 读取客户端数据socket.on('data', (data) => {console.log('Received data:', data.toString());});// 向客户端发送数据socket.write('Hello, Client!\n');// 监听关闭事件socket.on('end', () => {console.log('Client disconnected.');});
});server.listen(3000, () => {console.log('Server listening on port 3000.');
});

访问:http://localhost:3000/

输出如下:

2.4、转换流(Transform)

转换流是一种特殊的双工流,可以修改或转换数据。常见的转换流包括压缩和解压缩流。

const zlib = require('zlib');
const fs = require('fs');// 创建一个可读流
const readableStream = fs.createReadStream('example.txt');// 创建一个转换流(压缩)
const gzip = zlib.createGzip();// 创建一个可写流
const writableStream = fs.createWriteStream('example.txt.gz');// 将可读流管道到转换流,再管道到可写流
readableStream.pipe(gzip).pipe(writableStream);// 监听完成事件
writableStream.on('finish', () => {console.log('File compressed successfully.');
});

输出如下:

example.txt.gz中打开example.txt文件,内容如下图所示:

关键字:苏州中心疫情_大型网站制作都有哪些_百度运营怎么做_网店代运营十大排名

版权声明:

本网仅为发布的内容提供存储空间,不对发表、转载的内容提供任何形式的保证。凡本网注明“来源:XXX网络”的作品,均转载自其它媒体,著作权归作者所有,商业转载请联系作者获得授权,非商业转载请注明出处。

我们尊重并感谢每一位作者,均已注明文章来源和作者。如因作品内容、版权或其它问题,请及时与我们联系,联系邮箱:809451989@qq.com,投稿邮箱:809451989@qq.com

责任编辑: