搜尋

首頁  >  問答  >  主體

node.js fs.stat读取的文件长度为0

谷歌找了一圈没找到答案,先贴代码:

const fs = require('fs')
fs.watch('./test.log', {}, (e) => {
  const stats = fs.statSync('./test.log') 
  console.log(stats.size)
})

当你不断往test.log文件添加文字,会先打出0再打出实际文件长度,如下所示

请问有谁知道是为什么么,求解释!!

补充一下:
运行代码后,我用编辑器打开test.log这个文件,手动的往里面写东西。这个会有影响么?

PHP中文网PHP中文网2822 天前786

全部回覆(3)我來回復

  • 怪我咯

    怪我咯2017-04-17 13:53:45

    列印發生變化時的信息,看看吧
    看看編輯器對文件執行了什麼操作,訪問/修改文件都會觸發文件變更事件
    node寫文件然後監控文件,沒有出現你說的問題,如下碼:

    var fs = require('fs');
    var util=require('util');
    
    fs.watch('./test.log', {}, function(e){
        var stats = fs.statSync('./test.log');
        console.log(util.inspect(stats));//打印发生变化时的信息
        console.log(stats.size)
    });
    
    var writeStream=fs.createWriteStream('./test.log', {
        flags: 'a+',
        defaultEncoding: 'utf8'
    });
    
    setInterval(function(){
        writeStream.write("a");
    },1000);

    回覆
    0
  • 伊谢尔伦

    伊谢尔伦2017-04-17 13:53:45

    沒試過,應該是你在添加文字的時候,文件被佔用了,

    回覆
    0
  • 怪我咯

    怪我咯2017-04-17 13:53:45

    只要ctrl+s就會執行2次

    回覆
    0
  • 取消回覆