Node.js的fs模块中,关于fs.watch的疑问

在学习Node.js的fs模块时候,有一个函数是fs.watch,用于监测文件目录是否有改变.然后编写了如下的测试代码:

var fs = require('fs');
var watch = './watch';
var done = './done';

fs.watch(watch, (err, file) => {
  if (file) {
    console.log(file);
    fs.rename(watch + '/' + file, done + '/' + file, (err) => {
      if (err) console.error(err);
    });
  }
});

这段程序是有问题的.假设我在watch目录下touch 1.txt, 则实际上会抛出异常:

lgtdeMacBook-Pro:test lgt$ node test.js
1.txt
1.txt
{ [Error: ENOENT: no such file or directory, rename './watch/1.txt' -> './done/1.txt']
  errno: -2,
  code: 'ENOENT',
  syscall: 'rename',
  path: './watch/1.txt',
  dest: './done/1.txt' }

这里很显然的告诉我们,1.txt居然出现了两次.第一次我们成功的通过rename从watch目录转移到done目录,从而导致第二次rename时候1.txt文件已经不存在.

疑问:

  1. 这里1.txt为什么会出现两次?

阅读 9.4k
1 个回答

因为你rename的时候又触发了一次

fs.watch的文档,回调签名不是(err, file) 而是(event, file),第一个参数告诉你发生了什么事情

撰写回答
你尚未登录,登录后可以
  • 和开发者交流问题的细节
  • 关注并接收问题和回答的更新提醒
  • 参与内容的编辑和改进,让解决方法与时俱进
推荐问题