Gewusst wie: Freigeben einer Systemressource
Aktualisiert: November 2007
Mit einem Using-Block können Sie sicherstellen, dass das System eine Ressource freigibt, wenn der Code den Block beendet. Dies ist hilfreich, wenn Sie eine Systemressource verwenden, die sehr viel Speicher beansprucht oder auf die auch andere Komponenten zugreifen.
So geben Sie eine Datenbankverbindung frei, wenn sie vom Code nicht mehr benötigt wird
Fügen Sie am Anfang der Quelldatei die entsprechende Imports-Anweisung (.NET-Namespace und Typ) für die Datenbankverbindung ein (in diesem Fall System.Data.SqlClient).
Erstellen Sie einen Using-Block mit der Using-Anweisung und der End Using-Anweisung. Fügen Sie in den Block den Code ein, der die Datenbankverbindung definiert.
Deklarieren Sie die Verbindung, und erstellen Sie eine Instanz davon als Teil der Using-Anweisung.
' Insert the following line at the beginning of your source file. Imports System.Data.SqlClient Public Sub AccessSql(ByVal s As String) Using sqc As New System.Data.SqlClient.SqlConnection(s) MsgBox("Connected with string """ & sqc.ConnectionString & """") End Using End Sub
Das System gibt die Ressource frei. Dies gilt unabhängig davon, wie der Block beendet wird, beispielsweise auch bei Auftreten einer nicht behandelten Ausnahme.
Sie können nur innerhalb des Using-Blocks auf sqc zugreifen, da der Gültigkeitsbereich auf den Block beschränkt ist.
Das gleiche Verfahren kann auch auf andere Systemressourcen wie ein Dateihandle oder einen COM-Wrapper angewendet werden. Sie verwenden einen Using-Block, wenn Sie sicher sein möchten, dass die Ressource auch anderen Komponenten zur Verfügung steht, nachdem Sie den Using-Block beendet haben.
Siehe auch
Aufgaben
Gewusst wie: Übertragen der Steuerung aus einer Kontrollstruktur
Gewusst wie: Ausführen von mehreren Aktionen für ein Objekt
Konzepte
Geschachtelte Steuerungsstrukturen
Referenz
Using-Anweisung (Visual Basic)