信息
您所需的主题如下所示。但此主题未包含在此库中。

NotifyFilters 枚举

指定要在文件或文件夹中监视的更改。

此枚举有一个 FlagsAttribute 特性,通过该特性可使其成员值按位组合。

命名空间:  System.IO
程序集:  System(在 System.dll 中)

[FlagsAttribute]
public enum NotifyFilters

成员名称说明
Attributes文件或文件夹的特性。
CreationTime文件或文件夹的创建时间。
DirectoryName目录名。
FileName文件名。
LastAccess文件或文件夹上一次打开的日期。
LastWrite上一次向文件或文件夹写入内容的日期。
Security文件或文件夹的安全设置。
Size文件或文件夹的大小。

可组合此枚举的成员以监视多种更改。 例如,可监视文件或文件夹大小方面的更改和安全设置方面的更改。 每当文件或文件夹的大小或安全设置方面有更改的时候,这将引发事件。

下面的示例创建 FileSystemWatcher,以监视运行时指定的目录。 组件设置为监视 LastWrite 和 LastAccess 时间的任何更改,以及目录中文本文件的创建、删除或重命名。 如果更改、创建或删除文件,文件路径将被输出到控制台。 在文件重命名后,旧路径和新路径都输出到控制台。

在此示例中使用 System.DiagnosticsSystem.IO 命名空间。


using System;
using System.IO;
using System.Security.Permissions;

public class Watcher
{

    public static void Main()
    {
    Run();

    }

    [PermissionSet(SecurityAction.Demand, Name="FullTrust")]
    public static void Run()
    {
        string[] args = System.Environment.GetCommandLineArgs();

        // If a directory is not specified, exit program.
        if(args.Length != 2)
        {
            // Display the proper way to call the program.
            Console.WriteLine("Usage: Watcher.exe (directory)");
            return;
        }

        // Create a new FileSystemWatcher and set its properties.
        FileSystemWatcher watcher = new FileSystemWatcher();
        watcher.Path = args[1];
        /* Watch for changes in LastAccess and LastWrite times, and
           the renaming of files or directories. */
        watcher.NotifyFilter = NotifyFilters.LastAccess | NotifyFilters.LastWrite
           | NotifyFilters.FileName | NotifyFilters.DirectoryName;
        // Only watch text files.
        watcher.Filter = "*.txt";

        // Add event handlers.
        watcher.Changed += new FileSystemEventHandler(OnChanged);
        watcher.Created += new FileSystemEventHandler(OnChanged);
        watcher.Deleted += new FileSystemEventHandler(OnChanged);
        watcher.Renamed += new RenamedEventHandler(OnRenamed);

        // Begin watching.
        watcher.EnableRaisingEvents = true;

        // Wait for the user to quit the program.
        Console.WriteLine("Press \'q\' to quit the sample.");
        while(Console.Read()!='q');
    }

    // Define the event handlers.
    private static void OnChanged(object source, FileSystemEventArgs e)
    {
        // Specify what is done when a file is changed, created, or deleted.
       Console.WriteLine("File: " +  e.FullPath + " " + e.ChangeType);
    }

    private static void OnRenamed(object source, RenamedEventArgs e)
    {
        // Specify what is done when a file is renamed.
        Console.WriteLine("File: {0} renamed to {1}", e.OldFullPath, e.FullPath);
    }
}



.NET Framework

受以下版本支持:4.5、4、3.5、3.0、2.0、1.1、1.0

.NET Framework Client Profile

受以下版本支持:4、3.5 SP1

Windows 8.1, Windows Server 2012 R2, Windows 8, Windows Server 2012, Windows 7, Windows Vista SP2, Windows Server 2008(不支持服务器核心角色), Windows Server 2008 R2(支持带 SP1 或更高版本的服务器核心角色;不支持 Itanium)

并不是.NET Framework 对每个平台的所有版本都提供支持。有关支持的版本的列表,请参见.NET Framework 系统要求.

社区附加资源

显示:
© 2014 Microsoft