Windows 系统,网易云会将当前播放的音乐写入 history 文件,用 golang 的 fsnotify 监视文件时事件会延迟个两三秒才到
用了下面的步骤试了一下,问题应该是在 fsnotify (或者我的代码)上
- fsnotify 监视文件,用 notepad 更改 -> Write 消息是即时的
- 网易云切歌,用 notepad 编辑 history 文件 -> notepad 提示已被编辑,消息是即时的
- fsnotify 监视文件,网易云切歌 -> Write 消息会延迟几秒到
虽然有点延迟可以接受,但是非常想搞明白原因是什么。希望有人来科普一下或者甩个关键词
贴个代码,方便大家复现(
package main
import (
"github.com/fsnotify/fsnotify"
"os"
)
func main() {
watcher, _ := fsnotify.NewWatcher()
defer watcher.Close()
_ = watcher.Add()
for {
select {
case event, ok := <-watcher.Events:
if !ok {
return
}
fmt.Println(event)
case err, ok := <-watcher.Errors:
if !ok {
return
}
fmt.Println("error:", err)
}
}
for{
//runtime.Gosched()
time.Sleep(1* time.Second)
}
}