Bei der Arbeit mit Stream-Objekten wie Stream, StreamReader und StreamWriter ist es wichtig, den geeigneten Ansatz für die Objektentsorgung zu berücksichtigen. Sowohl die Close()- als auch die Dispose()-Methode sind verfügbar, aber die Semantik und Konventionen für ihre Verwendung variieren.
Close()-Methode
Die Close()-Methode löscht alle gepufferten Daten aus dem Stream und gibt alle von ihr verwendeten Systemressourcen frei. Dies ist ein häufiger Vorgang und trägt dazu bei, die Datenintegrität sicherzustellen, indem sofortiges Zurückschreiben erzwungen wird.
Dispose()-Methode
Die Dispose()-Methode folgt der IDisposable-Schnittstelle und ist ist für die Bereinigung verwalteter Ressourcen vorgesehen. Es ruft die geschützte Dispose(bool disposing)-Methode auf, die intern Close() aufruft und zusätzliche Bereinigungsaufgaben ausführt, wie z. B. die Freigabe verwalteter Ressourcen.
Gemäß dem untersuchten Code Bei Verwendung von Reflector.NET rufen die Close()-Methoden in StreamReader und StreamWriter intern Dispose(true) auf. Daher löst der Aufruf einer der beiden Methoden sowohl Lösch- als auch Bereinigungsvorgänge aus.
Basierend auf dem Verständnis von Close() und Dispose() besteht die empfohlene Best Practice darin, beide Methoden als zu verwenden folgt:
using (var stream = ...) { // Perform operations on the stream stream.Close(); }
Dieser Ansatz vereint die Vorteile beider Methoden:
Das in der Frage genannte MSDN-Beispiel verwendet Close() ohne using(), was gültig, aber veraltet ist Ansatz. Die oben beschriebene empfohlene Vorgehensweise verbessert die Lesbarkeit und Sicherheit des Codes.
Das obige ist der detaillierte Inhalt vonClose() oder Dispose(): Was ist die beste Vorgehensweise für die Stream-Objekt-Entsorgung in C#?. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!