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

查看:162
本文介绍了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这个文件,手动的往里面写东西。这个会有影响么?

解决方案

打印发生变化时的信息,看看吧
看看编辑器对文件执行了什么操作,访问/修改文件都会触发文件变更事件
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);

这篇关于node.js fs.stat读取的文件长度为0的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持IT屋!

查看全文
登录 关闭
扫码关注1秒登录
发送“验证码”获取 | 15天全站免登陆