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

 小水沉伦 发布于 2022-11-02 12:29

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

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

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

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

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

3 个回答
  • 只要ctrl+s就会执行2次

    2022-11-12 01:50 回答
  • 没试过,应该是你在添加文字的时候,文件被占用了,

    2022-11-12 01:50 回答
  • 打印发生变化时的信息,看看吧
    看看编辑器对文件执行了什么操作,访问/修改文件都会触发文件变更事件
    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);
    2022-11-12 01:50 回答
撰写答案
今天,你开发时遇到什么问题呢?
立即提问
热门标签
PHP1.CN | 中国最专业的PHP中文社区 | PNG素材下载 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有