Freigeben über


FileSystemWatcher Konstruktoren

Definition

Initialisiert eine neue Instanz der FileSystemWatcher-Klasse.

Überlädt

Name Beschreibung
FileSystemWatcher()

Initialisiert eine neue Instanz der FileSystemWatcher-Klasse.

FileSystemWatcher(String)

Initialisiert eine neue Instanz der FileSystemWatcher Klasse, wenn das angegebene Verzeichnis überwacht werden soll.

FileSystemWatcher(String, String)

Initialisiert eine neue Instanz der FileSystemWatcher Klasse, wobei das angegebene Verzeichnis und der Typ der zu überwachenden Dateien angegeben sind.

FileSystemWatcher()

Quelle:
FileSystemWatcher.cs
Quelle:
FileSystemWatcher.cs
Quelle:
FileSystemWatcher.cs
Quelle:
FileSystemWatcher.cs
Quelle:
FileSystemWatcher.cs

Initialisiert eine neue Instanz der FileSystemWatcher-Klasse.

public:
 FileSystemWatcher();
public FileSystemWatcher();
Public Sub New ()

Beispiele

Im folgenden Beispiel wird ein FileSystemWatcher Objekt erstellt, um das zur Laufzeit angegebene Verzeichnis anzuzeigen. Das FileSystemWatcher Objekt überwacht Änderungen und LastWriteLastAccess Uhrzeiten sowie die Erstellung, Löschung oder Umbenennung von Textdateien im Verzeichnis. Wenn eine Datei geändert, erstellt oder gelöscht wird, wird der Pfad zu der Datei in der Konsole angezeigt. Wenn eine Datei umbenannt wird, werden die alten und neuen Pfade in der Konsole angezeigt.

In diesem Beispiel werden die Namespaces und System.IO die System.Diagnostics Namespaces verwendet.

using System;
using System.IO;

namespace MyNamespace
{
    class MyClassCS
    {
        static void Main()
        {
            using var watcher = new FileSystemWatcher(@"C:\path\to\folder");

            watcher.NotifyFilter = NotifyFilters.Attributes
                                 | NotifyFilters.CreationTime
                                 | NotifyFilters.DirectoryName
                                 | NotifyFilters.FileName
                                 | NotifyFilters.LastAccess
                                 | NotifyFilters.LastWrite
                                 | NotifyFilters.Security
                                 | NotifyFilters.Size;

            watcher.Changed += OnChanged;
            watcher.Created += OnCreated;
            watcher.Deleted += OnDeleted;
            watcher.Renamed += OnRenamed;
            watcher.Error += OnError;

            watcher.Filter = "*.txt";
            watcher.IncludeSubdirectories = true;
            watcher.EnableRaisingEvents = true;

            Console.WriteLine("Press enter to exit.");
            Console.ReadLine();
        }

        private static void OnChanged(object sender, FileSystemEventArgs e)
        {
            if (e.ChangeType != WatcherChangeTypes.Changed)
            {
                return;
            }
            Console.WriteLine($"Changed: {e.FullPath}");
        }

        private static void OnCreated(object sender, FileSystemEventArgs e)
        {
            string value = $"Created: {e.FullPath}";
            Console.WriteLine(value);
        }

        private static void OnDeleted(object sender, FileSystemEventArgs e) =>
            Console.WriteLine($"Deleted: {e.FullPath}");

        private static void OnRenamed(object sender, RenamedEventArgs e)
        {
            Console.WriteLine($"Renamed:");
            Console.WriteLine($"    Old: {e.OldFullPath}");
            Console.WriteLine($"    New: {e.FullPath}");
        }

        private static void OnError(object sender, ErrorEventArgs e) =>
            PrintException(e.GetException());

        private static void PrintException(Exception? ex)
        {
            if (ex != null)
            {
                Console.WriteLine($"Message: {ex.Message}");
                Console.WriteLine("Stacktrace:");
                Console.WriteLine(ex.StackTrace);
                Console.WriteLine();
                PrintException(ex.InnerException);
            }
        }
    }
}
Imports System.IO

Namespace MyNamespace

    Class MyClassVB

        Shared Sub Main()
            Using watcher = New FileSystemWatcher("C:\path\to\folder")
                watcher.NotifyFilter = NotifyFilters.Attributes Or
                                       NotifyFilters.CreationTime Or
                                       NotifyFilters.DirectoryName Or
                                       NotifyFilters.FileName Or
                                       NotifyFilters.LastAccess Or
                                       NotifyFilters.LastWrite Or
                                       NotifyFilters.Security Or
                                       NotifyFilters.Size

                AddHandler watcher.Changed, AddressOf OnChanged
                AddHandler watcher.Created, AddressOf OnCreated
                AddHandler watcher.Deleted, AddressOf OnDeleted
                AddHandler watcher.Renamed, AddressOf OnRenamed
                AddHandler watcher.Error, AddressOf OnError

                watcher.Filter = "*.txt"
                watcher.IncludeSubdirectories = True
                watcher.EnableRaisingEvents = True

                Console.WriteLine("Press enter to exit.")
                Console.ReadLine()
            End Using
        End Sub

        Private Shared Sub OnChanged(sender As Object, e As FileSystemEventArgs)
            If e.ChangeType <> WatcherChangeTypes.Changed Then
                Return
            End If
            Console.WriteLine($"Changed: {e.FullPath}")
        End Sub

        Private Shared Sub OnCreated(sender As Object, e As FileSystemEventArgs)
            Dim value As String = $"Created: {e.FullPath}"
            Console.WriteLine(value)
        End Sub

        Private Shared Sub OnDeleted(sender As Object, e As FileSystemEventArgs)
            Console.WriteLine($"Deleted: {e.FullPath}")
        End Sub

        Private Shared Sub OnRenamed(sender As Object, e As RenamedEventArgs)
            Console.WriteLine($"Renamed:")
            Console.WriteLine($"    Old: {e.OldFullPath}")
            Console.WriteLine($"    New: {e.FullPath}")
        End Sub

        Private Shared Sub OnError(sender As Object, e As ErrorEventArgs)
            PrintException(e.GetException())
        End Sub

        Private Shared Sub PrintException(ex As Exception)
            If ex IsNot Nothing Then
                Console.WriteLine($"Message: {ex.Message}")
                Console.WriteLine("Stacktrace:")
                Console.WriteLine(ex.StackTrace)
                Console.WriteLine()
                PrintException(ex.InnerException)
            End If
        End Sub

    End Class

End Namespace

Hinweise

Sie können keinen Remotecomputer überwachen, der nicht über Windows NT oder Windows 2000 verfügt. Sie können einen Windows NT 4.0-Remotecomputer nicht von einem Windows NT 4.0-Computer aus ansehen.

In der folgenden Tabelle sind die anfänglichen Eigenschaftswerte für eine Instanz von FileSystemWatcher.

Eigentum Anfangswert
NotifyFilter bitweise OR-Kombination von LastWrite, FileNameund DirectoryName
EnableRaisingEvents false
Filter "*.*" (Alle Dateien ansehen.)
IncludeSubdirectories false
InternalBufferSize 8192
Path leere Zeichenfolge ("")

Hinweis

Die Komponente überwacht das angegebene Verzeichnis Path erst nach dem Festlegen und EnableRaisingEvents ist true.

Weitere Informationen

Gilt für:

FileSystemWatcher(String)

Quelle:
FileSystemWatcher.cs
Quelle:
FileSystemWatcher.cs
Quelle:
FileSystemWatcher.cs
Quelle:
FileSystemWatcher.cs
Quelle:
FileSystemWatcher.cs

Initialisiert eine neue Instanz der FileSystemWatcher Klasse, wenn das angegebene Verzeichnis überwacht werden soll.

public:
 FileSystemWatcher(System::String ^ path);
public FileSystemWatcher(string path);
new System.IO.FileSystemWatcher : string -> System.IO.FileSystemWatcher
Public Sub New (path As String)

Parameter

path
String

Das Verzeichnis, das überwacht werden soll, in der Standard- oder UNC-Schreibweise (Universal Naming Convention).

Ausnahmen

Der path Parameter ist null.

Der path Parameter ist eine leere Zeichenfolge ("").

- oder -

Der durch den path Parameter angegebene Pfad ist nicht vorhanden.

path ist zu lang.

Hinweise

Hinweis

Die Komponente überwacht das angegebene Verzeichnis Path erst nach dem Festlegen und EnableRaisingEvents ist true.

Die Komponente kann Dateien auf Ihrem Persönlichen Computer, einem Netzlaufwerk oder einem Remotecomputer überwachen.

Sie können keinen Remotecomputer überwachen, der nicht über Windows NT oder Windows 2000 verfügt. Sie können einen Windows NT 4.0-Remotecomputer nicht von einem Windows NT 4.0-Computer aus ansehen. Die Filter Eigenschaft ist standardmäßig so festgelegt, dass alle Dateien überwacht werden.

Weitere Informationen

Gilt für:

FileSystemWatcher(String, String)

Quelle:
FileSystemWatcher.cs
Quelle:
FileSystemWatcher.cs
Quelle:
FileSystemWatcher.cs
Quelle:
FileSystemWatcher.cs
Quelle:
FileSystemWatcher.cs

Initialisiert eine neue Instanz der FileSystemWatcher Klasse, wobei das angegebene Verzeichnis und der Typ der zu überwachenden Dateien angegeben sind.

public:
 FileSystemWatcher(System::String ^ path, System::String ^ filter);
public FileSystemWatcher(string path, string filter);
new System.IO.FileSystemWatcher : string * string -> System.IO.FileSystemWatcher
Public Sub New (path As String, filter As String)

Parameter

path
String

Das Verzeichnis, das überwacht werden soll, in der Standard- oder UNC-Schreibweise (Universal Naming Convention).

filter
String

Der Typ der zu überwachenden Dateien. Beispiel: "*.txt" überwacht Änderungen an allen Textdateien.

Ausnahmen

Der path Parameter ist null.

- oder -

Der filter Parameter ist null.

Der path Parameter ist eine leere Zeichenfolge ("").

- oder -

Der durch den path Parameter angegebene Pfad ist nicht vorhanden.

path ist zu lang.

Hinweise

Hinweis

Die Komponente überwacht das angegebene Verzeichnis Path erst nach dem Festlegen und EnableRaisingEvents ist true.

Die Komponente kann Dateien auf Ihrem Persönlichen Computer, einem Netzlaufwerk oder einem Remotecomputer überwachen.

Sie können keinen Remotecomputer überwachen, der nicht über Windows NT oder Windows 2000 verfügt. Sie können einen Windows NT 4.0-Remotecomputer nicht von einem Windows NT 4.0-Computer aus ansehen.

Weitere Informationen

Gilt für: