nodejs의 모든 파일 관련 작업은 fs 모듈에 있으며 읽기 및 쓰기 작업은 우리가 자주 사용하는 작업입니다. nodejs의 fs 모듈은 읽기 작업을 위해 readFile, read 및 createReadStream의 세 가지 메서드를 제공합니다. , writeFile, write 및 createWriteStream의 세 가지 메소드를 제공합니다. 차이점을 분석해 보겠습니다.
1. readFile 및 writeFile
1. readFile 메소드는 읽을 파일의 내용입니다. 캐시 영역을 완전히 읽은 다음 캐시 영역에서 파일 내용을 읽습니다. 구체적인 작업은 다음과 같습니다.
fs.readFile('./test.txt', 'utf8', function(err, data){ console.log(data); });
해당 동기화 방법은 다음과 같습니다.
var data = fs.readFileSync('./test.txt', 'utf8'); console.log(data);
동기 방법과 비동기 방법의 차이점은 다음과 같습니다. : 동기화를 사용하는 경우 메서드에 의해 수행된 작업이 완료되기 전에는 후속 코드를 실행할 수 없습니다. 비동기 메서드는 작업 결과를 콜백 함수의 매개 변수로 반환하므로 후속 코드를 즉시 실행할 수 있습니다. , 읽기가 완료된 후 해당 콜백 함수가 호출됩니다.
2 writeFile 메소드는 캐시 영역에 쓸 파일의 전체 내용을 읽은 다음 캐시 영역의 내용을 한 번에 파일에 쓰는 것입니다.
//异步方法 fs.writeFile('./message.txt', '这是第一行',function(err){ if(err) console.log('写文件操作失败'); else console.log('写文件操作成功'); }); //同步方法 fs.writeFileSync('./message.txt','这是第一行');
위의 읽기 및 쓰기 작업의 경우 Node.js는 파일 콘텐츠를 전체적으로 처리하고 이에 대한 캐시 영역을 할당한 후 파일 콘텐츠를 한 번에 캐시 영역으로 읽습니다. 기간 동안 Node.js는 기타 처리를 실행할 수 없습니다. 따라서 대용량 파일을 읽고 쓸 때 캐시 영역이 "폭발"될 수 있습니다.
2. 읽기 및 쓰기
1. read 또는 readSync 메서드는 파일의 작은 내용을 캐시 영역으로 지속적으로 읽어 파일의 내용을 읽은 후 마지막으로 파일을 읽습니다.
var fs = require('fs'); fs.open('./message.txt','r',function(err,fd){ var buf = new Buffer(225); //读取fd文件内容到buf缓存区 fs.read(fd,buf,0,9,3,function(err,bytesRead,buffer){ console.log(buf.slice(0,bytesRead).toString()); }); var buff = new Buffer(225); //位置设置为null会默认从文件当前位置读取 fs.read(fd,buff,0,3,null,function(err,bytesRead,buffer){ console.log(buff.slice(0,bytesRead).toString()); }); var buffer = new Buffer(225); //同步方法读取文件 var bytesRead = fs.readFileSync(fd,buffer,0,9,3); console.log(bytesRead); console.log(buffer.slice(0,bytesRead).toString()); });
2. write 또는 writeSync 메소드가 컨텐츠를 쓸 때 node.js는 다음 프로세스를 수행합니다. 1. 메모리 캐시 영역에 쓸 데이터를 씁니다. 2. 캐시 영역이 가득 찰 때까지 기다립니다. 그런 다음 캐시 영역의 내용을 파일에 씁니다. 3 모든 데이터가 파일에 기록될 때까지 1단계와 2단계를 반복합니다. 구체적인 작업은 다음과 같습니다.
var fs = require('fs');var buf = new Buffer('我喜爱编程'); fs.open('./mess.txt','w',function(err,fd){ fs.write(fd,buf,3,9,0,function(err,written,buffer){ fs.write(fd,buf,12,3,null,function(err,written,buffer){ if(err) console.log('写文件操作失败'); console.log('写文件操作成功'); }); }); //同步写入 fs.writeSync(fd,buf,3,9,0); });
위의 읽기 및 쓰기 작업의 경우 node.js는 파일을 여러 조각으로 나누어 단계별로 작업하므로 파일을 읽고 쓰는 과정에서 다른 작업을 수행할 수 있습니다. .
但有的时候我们并不关心整个文件的内容,而只关注从文件中读取到的某些数据,以及读取到数据时需要执行的处理,这时我们可以使用文件流来处理。
三、createReadStream和createWriteStream
1、createReadStream方法创建一个将文件内容读取为流数据的ReadStream对象,方法如下所示:
var fs = require('fs');var readStream = fs.createReadStream('./message.txt',{start:3,end:12}); readStream.on('open',function(fd){ console.log('开始读取文件'); }); readStream.on('data',function(data){ console.log('读取到数据:'); console.log(data); }); readStream.on('end',function(){ console.log('文件已全部读取完毕'); }); readStream.on('close',function(){ console.log('文件被关闭'); }); readStream.on('error',function(err){ console.log('读取文件失败'); });
2、createWriteStream方法创建一个将流数据写入文件中的WriteStream对象,方法如下所示:
var fs = require('fs');var file = fs.createReadStream('./message.txt');var out = fs.createWriteStream('./anotherMessage.txt'); file.on('data',function(data){ out.write(data); }); out.on('open',function(fd){ console.log('需要被写入的文件已打开'); }); file.on('end',function(){ //将操作系统缓存区中的数据全部写入文件 out.end('再见',function(){ console.log('文件全部写入完毕'); console.log('共写入'+out.bytesWritten+'数据'); }); });
以上方法可以对读写文件的过程中进行监听,并定义相关的方法pause和resume暂停或恢复文件的读取操作,可以监听写入时缓存区数据是否已满或者是否已全部输出,如下所示:
//监听writeStream对象的drain事件var fs = require('fs');var out = fs.createWriteStream('./test1.txt');for(var i=0;i<10000;i++){ //返回true或false true代表缓存区已满 var flag = out.write(i.toString()); console.log(flag); } out.on('drain',function(){ console.log('操作系统缓存区中的数据已全部输出'); var out = fs.createWriteStream('./test2.txt'); for(var i=0;i<10;i++){ var flag = out.write(i.toString()); console.log(flag); } out.on('drain',function(){ console.log('操作系统缓存区中的数据已全部输出'); }); });
위 내용은 nodeJS에서 파일을 읽고 쓰는 세 가지 방법의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!