- A+
在开发各种应用程序时,我们经常需要对文件系统中的文件或文件夹进行实时监测,以便在文件内容改变、文件被创建或删除时能够及时做出反应。在 C# 中,System.IO.FileSystemWatcher 类为我们提供了这样一个强大的功能。
一、引入 FileSystemWatcher 类
首先,在项目中引入 System.IO 命名空间,这是使用 FileSystemWatcher 类的前提:
using System.IO;
二、创建并配置 FileSystemWatcher 实例
下面是一个简单的例子,展示了如何创建一个 FileSystemWatcher 实例并设置其监视的目录、事件类型以及事件处理函数:
public class FileFolderMonitor { private FileSystemWatcher _fileWatcher; public void StartMonitoring(string directoryPath) { // 创建 FileSystemWatcher 实例 _fileWatcher = new FileSystemWatcher(); // 设置要监视的目录路径 _fileWatcher.Path = directoryPath; // 设置要监视的更改类型(例如:修改、创建、删除) _fileWatcher.NotifyFilter = NotifyFilters.LastWrite | NotifyFilters.FileName | NotifyFilters.DirectoryName; // 添加事件处理程序 _fileWatcher.Changed += OnChanged; _fileWatcher.Created += OnChanged; _fileWatcher.Deleted += OnChanged; _fileWatcher.Renamed += OnRenamed; // 开启事件监听 _fileWatcher.EnableRaisingEvents = true; Console.WriteLine($"已开始监视文件夹: {directoryPath}"); } private void OnChanged(object source, FileSystemEventArgs e) { Console.WriteLine($"文件或文件夹发生变更: {e.FullPath},事件类型: {e.ChangeType}"); } private void OnRenamed(object source, RenamedEventArgs e) { Console.WriteLine($"文件或文件夹被重命名: 旧路径 {e.OldFullPath} -> 新路径 {e.FullPath}"); } public void StopMonitoring() { if (_fileWatcher != null) { // 停止引发事件 _fileWatcher.EnableRaisingEvents = false; // 清理资源 _fileWatcher.Dispose(); _fileWatcher = null; Console.WriteLine("已停止监视文件夹"); } } }
三、使用与注意事项
-
在上述代码中,我们通过调用 StartMonitoring 方法启动了对指定目录的监视,并且在文件或子目录发生变化时触发相应的事件处理器。
-
NotifyFilter 属性用来定义需要监听的具体事件类型,如最后写入时间、文件名和目录名的变化等。
-
Changed、Created、Deleted 和 Renamed 四个事件分别对应于文件或文件夹的内容更改、新建、删除和重命名操作。
-
注意事项:
-
FileSystemWatcher 类并不能保证事件的即时性或顺序性,尤其是在大量并发文件操作的情况下,可能会合并或延迟触发事件。
-
使用 FileSystemWatcher 时应确保合理处理资源,特别是当不再需要监视时,应及时调用 Dispose 方法释放资源。
-
总结来说,System.IO.FileSystemWatcher 是实现文件系统实时监控的强大工具,只需简单配置和事件处理,就能让我们的应用程序具备灵敏响应文件系统变化的能力。
四、课外探索,弹出文件选择框
public static string SelectFolder(string description = "请选择一个文件夹:", Environment.SpecialFolder rootFolder = Environment.SpecialFolder.MyComputer) { using (FolderBrowserDialog folderDialog = new FolderBrowserDialog()) { folderDialog.Description = description; folderDialog.RootFolder = rootFolder; if (folderDialog.ShowDialog() == DialogResult.OK) { return folderDialog.SelectedPath; } } return string.Empty; }