关于 fsnotify 在监听文件的写入事件时,消息不即时这件事

2021-04-15 14:31:36 +08:00
 Misakas

Windows 系统,网易云会将当前播放的音乐写入 history 文件,用 golang 的 fsnotify 监视文件时事件会延迟个两三秒才到

用了下面的步骤试了一下,问题应该是在 fsnotify (或者我的代码)上

虽然有点延迟可以接受,但是非常想搞明白原因是什么。希望有人来科普一下或者甩个关键词

贴个代码,方便大家复现(

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)
	}
}

978 次点击
所在节点    问与答
2 条回复
zpfhbyx
2021-04-15 16:21:30 +08:00
_ = watcher.Add() 这是监测了所有了吧?
Misakas
2021-04-15 21:26:01 +08:00
@zpfhbyx 发帖时不小心修改错了了,watcher.Add() 其实是有值的

这是一个专为移动设备优化的页面(即为了让你能够在 Google 搜索结果里秒开这个页面),如果你希望参与 V2EX 社区的讨论,你可以继续到 V2EX 上打开本讨论主题的完整版本。

https://www.v2ex.com/t/770851

V2EX 是创意工作者们的社区,是一个分享自己正在做的有趣事物、交流想法,可以遇见新朋友甚至新机会的地方。

V2EX is a community of developers, designers and creative people.

© 2021 V2EX