您好,登錄后才能下訂單哦!
本文小編為大家詳細介紹“怎么使用Go語言fsnotify接口實現監測文件修改”,內容詳細,步驟清晰,細節處理妥當,希望這篇“怎么使用Go語言fsnotify接口實現監測文件修改”文章能幫助大家解決疑惑,下面跟著小編的思路慢慢深入,一起來學習新知識吧。
$ go get github.com/fsnotify/fsnotify
我們先來了解下fsnotify工具的所有類型。
Event結構體表示單個文件系統通知。
函數String()返回一個“file: REMOVE|WRITE|…”格式字符串表示事件的字符串。
type Event struct { Name string //文件或目錄的相對路徑 Op Op //文件更改事件 } func (e Event) String() string
該工具描述了一組文件操作。它們是可以觸發通知的通用文件操作。
type Op uint32 const ( Create Op = 1 << iota Write Remove Rename Chmod )
Watcher結構體是該工具的核心。包含兩個channel和三個函數。
type Watcher struct { Events chan Event Errors chan error ... } func (w *Watcher) Add(name string) error func (w *Watcher) Remove(name string) error func NewWatcher() (*Watcher, error)
Events 通道
Errors 通道
Add:非遞歸監測文件或目錄的變化。
Remove:停止監測文件或目錄。
Close:關閉所有文件或目錄的監測以及關閉Events通道。
函數NewWatcher通過底層操作系統調用創建watcher對象,并等待事件通知。
func NewWatcher() (*Watcher, error)
import ( "log" "github.com/fsnotify/fsnotify" ) func main() { watcher, err := fsnotify.NewWatcher() if err != nil { log.Fatal("new watcher failed: ", err) } defer watcher.Close() done := make(chan bool) go func() { defer close(done) for { select { case event, ok := <-watcher.Events: if !ok { return } log.Printf("%s %s\n", event.Name, event.Op) case err, ok := <-watcher.Errors: if !ok { return } log.Println("error: ", err) } } }() err = watcher.Add("./") if err != nil { log.Fatal("add failed:", err) } <-done }
上面的代碼通過啟動一個goroutine在后臺監測目錄或文件的變化,調用函數watcher.Add("./")添加監測的目錄是當前目錄,也就是main.go文件所在目錄。
運行程序后,如果你修改下當前main.go文件會產生如下結果:
Output
2022/06/09 07:01:15 main.go~ CREATE
2022/06/09 07:01:15 main.go WRITE|CHMOD
2022/06/09 07:01:15 main.go~ CREATE
2022/06/09 07:01:15 main.go CHMOD
2022/06/09 07:01:15 main.go WRITE
2022/06/09 07:01:15 main.go~ REMOVE
2022/06/09 07:01:16 main.go CHMOD
上面的輸出過程可以發現,修改文件并保存會觸發以下動作:
CREATE動作即臨時文件的創建
WRITE寫文件動作
CHMOD修改文件屬性
REMOVE刪除臨時文件。
讀到這里,這篇“怎么使用Go語言fsnotify接口實現監測文件修改”文章已經介紹完畢,想要掌握這篇文章的知識點還需要大家自己動手實踐使用過才能領會,如果想了解更多相關內容的文章,歡迎關注億速云行業資訊頻道。
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。