Using-Anweisung (Visual Basic)
Deklariert den Beginn eines Using-Blocks und ruft optional die Systemressourcen ab, die von dem Block gesteuert werden.
Using { resourcelist | resourceexpression }
[ statements ]
End Using
Teile
Begriff |
Definition |
resourcelist |
Erforderlich, wenn Sie resourceexpression nicht angeben. Liste mit einer oder mehreren Systemressourcen die Steuerelemente Using dieses Blocks, durch Trennzeichen getrennt. |
resourceexpression |
Erforderlich, wenn Sie resourcelist nicht angeben. Verweisvariable oder -ausdruck, die bzw. der auf eine Systemressource verweist, die von diesem Using-Block gesteuert werden soll. |
statements |
Dies ist optional. Block von Anweisungen, die vom Using-Block ausgeführt werden. |
End Using |
Erforderlich. Beendet die Definition des Using-Blocks und gibt alle Ressourcen frei, die von dem Block gesteuert werden. |
Jede Ressource im resourcelist-Teil weist die folgende Syntax und die folgenden Bestandteile auf:
resourcename As New resourcetype [ ( [ arglist ] ) ]
- oder -
resourcename As resourcetype = resourceexpression
Bestandteile von "resourcelist"
Begriff |
Definition |
resourcename |
Erforderlich. Verweisvariable, die auf eine vom Using-Block gesteuerte Systemressource verweist. |
New |
Erforderlich, wenn die Using-Anweisung die Ressource abruft. Wenn Sie die Ressource bereits abgerufen haben, verwenden Sie die zweite Alternative der Syntax. |
resourcetype |
Erforderlich. Die Klasse der Ressource. Die Klasse muss die IDisposable-Schnittstelle implementieren. |
arglist |
Dies ist optional. Liste der Argumente, die Sie an den Konstruktor übergeben, um eine Instanz von resourcetype zu erstellen. Siehe Parameterliste (Visual Basic). |
resourceexpression |
Erforderlich. Variable oder Ausdruck, der bzw. die auf eine Systemressource verweist, die die Anforderungen von resourcetype erfüllt. Wenn Sie die zweite Alternative der Syntax verwenden, müssen Sie die Ressource abrufen, bevor die Steuerung an die Using-Anweisung übergeben wird. |
Hinweise
Zuweilen erfordert Code eine nicht verwaltete Ressource, z. B. ein Dateihandle, einen COM-Wrapper oder eine SQL-Verbindung. Mit einem Using-Block wird die Freigabe einer oder mehrerer dieser Ressourcen nach ihrer Behandlung durch den Code sichergestellt. Hierdurch werden sie für die Verwendung durch anderen Code verfügbar.
Verwaltete Ressourcen werden vom Garbage Collector (GC) von .NET Framework freigegeben. Sie müssen hierfür keinen zusätzlichen Code schreiben. Für verwaltete Ressourcen ist kein Using-Block erforderlich. Dennoch können Sie einen Using-Block verwenden, um die Beseitigung einer verwalteten Ressource zu erzwingen anstatt auf den Garbage Collector zu warten.
Ein Using-Block besteht aus drei Teilen: Abruf, Verwendung und Freigabe.
Abruf bedeutet, dass eine Variable erstellt und für den Verweis auf die Systemressource initialisiert wird. Die Using-Anweisung kann eine oder mehrere Ressourcen abrufen. Sie können auch genau eine Ressource abrufen, bevor der Block ausgeführt wird, und sie für die Using-Anweisung bereitstellen. Wenn Sie resourceexpression angeben, müssen Sie die Ressource abrufen, bevor die Steuerung an die Using-Anweisung übergeben wird.
Verwendung bedeutet, dass auf die Ressourcen zugegriffen wird und Aktionen mit ihnen ausgeführt werden. Die Anweisungen zwischen Using und End Using stellen die Verwendung der Ressourcen dar.
Freigabe bedeutet, dass für das Objekt in resourcename die Dispose-Methode aufgerufen wird. Dies ermöglicht dem Objekt, seine Ressourcen sauber zu beenden. Mit der End Using-Anweisung werden die vom Using-Block gesteuerten Ressourcen freigegeben.
Verhalten
Das Verhalten eines Using-Blocks entspricht dem Verhalten einer Try...Finally-Konstruktion, in deren Try-Block die Ressourcen verwendet und in deren Finally-Block die Ressourcen freigegeben werden. Aus diesem Grund wird die Freigabe der Ressourcen durch den Using-Block sichergestellt, unabhängig davon, wie Sie den Block beenden. Dies gilt sogar im Fall einer nicht behandelten Ausnahme, allerdings nicht bei einer StackOverflowException.
Der Gültigkeitsbereich jeder von der Using-Anweisung abgerufenen Ressourcenvariablen ist auf den Using-Block beschränkt.
Wenn Sie in der Using-Anweisung mehrere Systemressourcen angeben, hat dies dieselbe Auswirkung wie das Schachteln mehrerer Using-Blocks.
Wenn resourcenameNothing ist, wird kein Aufruf Dispose gemacht, und es wird keine Ausnahme ausgelöst.
Strukturierte Ausnahmebehandlung in einem Using-Block
Wenn Sie eine Ausnahme behandeln müssen, die möglicherweise in einem Using-Block auftritt, können Sie diesem eine vollständige Try...Finally-Konstruktion hinzufügen. Wenn Sie den Fall behandeln müssen, dass eine Ressource von einer Using-Anweisung nicht erfolgreich abgerufen wird, können Sie überprüfen, ob resourcename Nothing ist.
Strukturierte Ausnahmebehandlung anstelle eines Using-Blocks
Wenn Sie den Abruf der Ressourcen genauer steuern müssen oder wenn im Finally-Block zusätzlicher Code erforderlich ist, können Sie den Using-Block in eine Try...Finally-Konstruktion ändern. Im folgenden Beispiel werden die Skelette einer Try-Konstruktion und einer Using-Konstruktion veranschaulicht, die dem Abruf und der Freigabe von resource entsprechen.
Using resource As New resourceType
' Insert code to work with resource.
End Using
' For the acquisition and disposal of resource, the following
' Try construction is equivalent to the Using block.
Dim resource As New resourceType
Try
' Insert code to work with resource.
Finally
If resource IsNot Nothing Then
resource.Dispose()
End If
End Try
Hinweis
Der Code im Using-Block darf das Objekt in resourcename keiner anderen Ressource zuweisen.Beim Beenden des Using-Blocks wird die Ressource freigegeben, und die andere Variable kann nicht auf die Ressource zugreifen, auf die sie zeigt.
Beispiel
Im folgenden Beispiel wird eine Datei mit dem Namen log.txt, und schreibt zwei Textzeilen zur Datei. Außerdem liest dass dieselbe Datei und zeigt die Textzeilen an.
Da die TextWriter und TextReader-Klassen die IDisposable-Schnittstelle implementieren, kann der Code Using-Anweisungen verwenden, um sicherzustellen, dass die Datei ordnungsgemäß nach dem geschriebene und die Lesevorgänge geschlossen wird.
Private Sub WriteFile()
Using writer As System.IO.TextWriter = System.IO.File.CreateText("log.txt")
writer.WriteLine("This is line one.")
writer.WriteLine("This is line two.")
End Using
End Sub
Private Sub ReadFile()
Using reader As System.IO.TextReader = System.IO.File.OpenText("log.txt")
Dim line As String
line = reader.ReadLine()
Do Until line Is Nothing
Console.WriteLine(line)
line = reader.ReadLine()
Loop
End Using
End Sub
Siehe auch
Aufgaben
Gewusst wie: Freigeben einer Systemressource (Visual Basic)