欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

詳解nodeJS中讀寫文件方法的區(qū)別

 更新時間:2017年03月06日 08:53:35   作者:catmarry  
本篇文章主要介紹了詳解nodeJS中讀寫文件方法的區(qū)別,nodejs的fs模塊針對讀操作為我們提供了readFile,read, createReadStream三個方法,有興趣的可以了解一下。

導言:nodejs中所有與文件相關的操作都在fs模塊中,而讀寫操作又是我們會經常用到的操作,nodejs的fs模塊針對讀操作為我們提供了readFile,read, createReadStream三個方法,針對寫操作為我們提供了writeFile,write, createWriteStream三個方法,下面分析一下它們的區(qū)別:

一、readFile和writeFile

1、readFile方法是將要讀取的文件內容完整讀入緩存區(qū),再從該緩存區(qū)中讀取文件內容,具體操作如下:

fs.readFile('./test.txt', 'utf8', function(err, data){
  console.log(data); 
});

與其對應的同步方法為:

var data = fs.readFileSync('./test.txt', 'utf8');
console.log(data);

同步方法和異步方法的區(qū)別是:在使用同步方法執(zhí)行的操作結束之前,不能執(zhí)行后續(xù)代碼的執(zhí)行;而異步方法將操作結果作為回調函數的參數進行返回,方法調用之后,就可以立即執(zhí)行后續(xù)的代碼,讀取完畢后會調用對應的回調函數。

2、writeFile方法是將要寫入的文件內容完整的讀入緩存區(qū),然后一次性的將緩存區(qū)中的內容寫入都文件中,其同步和異步具體操作如下:

//異步方法
fs.writeFile('./message.txt', '這是第一行',function(err){
  if(err) console.log('寫文件操作失敗');
  else console.log('寫文件操作成功');
});

//同步方法
fs.writeFileSync('./message.txt','這是第一行');

以上的讀寫操作,Node.js將文件內容視為一個整體,為其分配緩存區(qū)并且一次性將文件內容讀取到緩存區(qū)中,在這個期間,Node.js將不能執(zhí)行任何其他處理。所以當讀寫大文件的時候,有可能造成緩存區(qū)“爆倉”。

二、read和write

1、read或readSync方法讀取文件內容是不斷地將文件中的一小塊內容讀入緩存區(qū),最后從該緩存區(qū)中讀取文件內容,具體操作如下:

var fs = require('fs');
fs.open('./message.txt','r',function(err,fd){
  var buf = new Buffer(225);
  //讀取fd文件內容到buf緩存區(qū)
  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執(zhí)行以下過程:1將需要寫入的數據寫入到一個內存緩存區(qū);2待緩存區(qū)寫滿后再將緩存區(qū)中的內容寫入到文件中;3重復執(zhí)行步驟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會將文件分成一塊一塊逐步操作,在讀寫文件過程中允許執(zhí)行其他操作。

但有的時候我們并不關心整個文件的內容,而只關注從文件中讀取到的某些數據,以及讀取到數據時需要執(zhí)行的處理,這時我們可以使用文件流來處理。

三、createReadStream和createWriteStream

1、createReadStream方法創(chuàng)建一個將文件內容讀取為流數據的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方法創(chuàng)建一個將流數據寫入文件中的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(){
  //將操作系統緩存區(qū)中的數據全部寫入文件
  out.end('再見',function(){
    console.log('文件全部寫入完畢');
    console.log('共寫入'+out.bytesWritten+'數據');
  });
});

以上方法可以對讀寫文件的過程中進行監(jiān)聽,并定義相關的方法pause和resume暫?;蚧謴臀募淖x取操作,可以監(jiān)聽寫入時緩存區(qū)數據是否已滿或者是否已全部輸出,如下所示:

//監(jiān)聽writeStream對象的drain事件
var fs = require('fs');
var out = fs.createWriteStream('./test1.txt');
for(var i=0;i<10000;i++){
  //返回true或false true代表緩存區(qū)已滿
  var flag = out.write(i.toString());
  console.log(flag);
}
out.on('drain',function(){
  console.log('操作系統緩存區(qū)中的數據已全部輸出');
  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('操作系統緩存區(qū)中的數據已全部輸出');
  });
});

以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持腳本之家。

相關文章

  • Node.js中的進程間通信

    Node.js中的進程間通信

    這篇文章主要介紹了Node.js中的進程間通信,文章圍繞主題展開詳細的內容戒殺,具有一定的參考價值,感興趣的小伙伴可以參考一下
    2022-09-09
  • 如何在Linux上安裝Node.js

    如何在Linux上安裝Node.js

    這篇文章主要為大家分享了如何在你的Linux發(fā)行版上安裝Node.js?感興趣的小伙伴們可以參考一下
    2016-04-04
  • NodeJs之word文件生成與解析的實現代碼

    NodeJs之word文件生成與解析的實現代碼

    這篇文章主要介紹了NodeJs之word文件生成與解析的實現代碼,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧
    2019-04-04
  • nodejs實現爬取網站圖片功能

    nodejs實現爬取網站圖片功能

    給大家通過一個實例來教學如何用nodejs實現爬取網站圖片功能,有興趣的朋友收藏一下吧。
    2017-12-12
  • Node.js事件循環(huán)(Event Loop)的使用

    Node.js事件循環(huán)(Event Loop)的使用

    事件循環(huán)是其非阻塞I/O和高并發(fā)能力的核心機制,本文主要介紹了Node.js事件循環(huán)(Event Loop)的使用,具有一定的參考價值,感興趣的可以了解一下
    2024-05-05
  • NodeJS和瀏覽器中this關鍵字的不同之處

    NodeJS和瀏覽器中this關鍵字的不同之處

    這篇文章主要給大家介紹了關于NodeJS和瀏覽器中this關鍵字不同的相關資料,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧
    2021-03-03
  • 詳解用node.js實現簡單的反向代理

    詳解用node.js實現簡單的反向代理

    本篇文章主要介紹了詳解用node.js實現簡單的反向代理,小編覺得挺不錯的,現在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2017-06-06
  • node.js事件循環(huán)機制及與js區(qū)別詳解

    node.js事件循環(huán)機制及與js區(qū)別詳解

    這篇文章主要為大家介紹了node.js事件循環(huán)機制及與js區(qū)別詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪
    2022-09-09
  • 詳解nodejs 文本操作模塊-fs模塊(五)

    詳解nodejs 文本操作模塊-fs模塊(五)

    本篇文章主要介紹了nodejs 文本操作模塊-fs模塊(五),這里再說最后一個我看來很重要的方法,監(jiān)聽文件或者目錄的的方法watchFile。有興趣的可以了解一下。
    2016-12-12
  • node.js利用redis數據庫緩存數據的方法

    node.js利用redis數據庫緩存數據的方法

    Redis數據庫采用極簡的設計思想,最新版的源碼包還不到2Mb。其在使用上也有別于一般的數據庫。下面這篇文章就來給大家介紹了node.js利用redis數據庫緩存數據的方法,需要的朋友可以參考借鑒,下面來一起看看吧。
    2017-03-03

最新評論