在学习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.txt为什么会出现两次?
因為你rename的時候又觸發了一次
看fs.watch的文檔,回呼簽名不是(err, file) 而是(event, file),第一個參數告訴你發生了什麼事情