Node.js поток (поток)
Поток представляет собой абстрактный интерфейс, узел имеет множество объектов реализуют этот интерфейс. Например, сервер, который инициировал запрос на объект запроса HTTP является потоком, а также стандартный вывод (стандартный вывод).
Node.js, поток Есть четыре типа потока:
Читаемые - читаемый операция.
Writable - операции записи.
Дуплекс - операции чтения и записи.
Transform - операционные данные должны быть записаны , а затем зачитывает результаты.
Все объекты являются экземплярами EventEmitter Stream. Общие мероприятия включают в себя:
Данные - срабатывает , когда данные времени считывания.
конец - не вызывая более считываемые данные.
Ошибка - активируется при возникновении ошибки в приеме и процесса записи.
отделка - Пожары , когда все данные были записаны в базовой системе.
Этот учебник будет ввести общие операции потока.
Чтение данных из потока
Создание input.txt файл, следующим образом:
本教程官网地址:www.w3big.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.w3big.com
Написать поток
Создание main.js файл, следующим образом:
var fs = require("fs"); var data = '本教程官网地址:www.w3big.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 файла данных. Результаты выполнения кода заключаются в следующем:
$ node main.js 程序执行完毕 写入完成。
Output.txt просмотреть содержимое файла:
$ cat output.txt 本教程官网地址:www.w3big.com
поток трубопровода
Трубопровод обеспечивает механизм для входного потока выходного потока. Как правило, мы использовали для получения данных, и передавать данные в другой поток из потока.Как показано на рисунке выше, мы сравнили документы ведро с водой, а вода содержимое документов, так что мы подключаем два ведра воды из ведра в другое ведро с трубой (труба), так медленно реализуется процесс репликации больших файлов.
Следующие примеры, которые мы хотим записать в другой файл, читая содержимое файла и содержимое.
Установка input.txt документа гласит:
本教程官网地址:www.w3big.com 管道流操作实例
Создание 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 本教程官网地址:www.w3big.com 管道流操作实例
Flow Chain
Цепь другой текущий поток и создать несколько потоков цепной механизм операционной, подключив выход. Цепь потока обычно используется для эксплуатации трубопровода.
Далее мы трубы и цепи для сжатия и распаковки файлов.
Создание 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 文件解压完成。