Option Infer-Anweisung
Ermöglicht die Verwendung des lokalen Typrückschlusses beim Deklarieren von Variablen.
Syntax
Option Infer { On | Off }
Bestandteile
Begriff | Definition |
---|---|
On |
Dies ist optional. Ermöglicht den lokalen Typrückschluss. |
Off |
Optional. Deaktiviert den lokalen Typrückschluss. |
Bemerkungen
Geben Sie zum Festlegen von Option Infer
in einer Datei am Anfang der Datei Option Infer On
oder Option Infer Off
ein. Wenn der in einer Datei für Option Infer
festgelegte Wert mit dem in der IDE oder in der Befehlszeile festgelegten Wert im Konflikt steht, hat der Wert in der Datei Vorrang.
Wenn Sie für Option Infer
On
festlegen, können Sie lokale Variablen deklarieren, ohne explizit einen Datentyp anzugeben. Der Compiler leitet den Datentyp einer Variablen vom Typ des Initialisierungsausdrucks ab.
In der folgenden Abbildung ist Option Infer
eingeschaltet. Die Variable in der Deklaration Dim someVar = 2
wird als ganze Zahl durch Typrückschluss deklariert.
Der folgende Screenshot zeigt IntelliSense, wenn Option Infer aktiviert ist:
In der folgenden Abbildung ist Option Infer
deaktiviert. Die Variable in der Deklaration Dim someVar = 2
ist durch Typrückschluss als Object
deklariert. In diesem Beispiel ist die Einstellung Option Strict auf der Kompilierungsseite, Projekt-Designer (Visual Basic) auf Off (Aus) festgelegt.
Der folgende Screenshot zeigt IntelliSense, wenn Option Infer deaktiviert ist:
Hinweis
Wenn eine Variable als Object
deklariert ist, kann sich der Laufzeittyp ändern, während das Programm ausgeführt wird. Visual Basic führt Vorgänge aus, die als Boxing und Unboxing bezeichnet werden, um die Konvertierung zwischen einem Object
und einem Werttyp vorzunehmen, was die Ausführung langsamer macht. Weitere Informationen zu Boxing und Unboxing finden Sie in der Visual Basic-Sprachspezifikation.
Typrückschluss findet auf Prozedurebene Anwendung und nicht außerhalb einer Prozedur in einer Klasse, Struktur, Modul oder Schnittstelle.
Weitere Informationen finden Sie unter Lokaler Typrückschluss.
Wenn eine Option Infer-Anweisung nicht vorhanden ist
Wenn der Quellcode keine Option Infer
-Anweisung enthält, wird die Option Infer-Einstellung auf der Kompilierungsseite, Projekt-Designer (Visual Basic) verwendet. Wenn der Befehlszeilencompiler verwendet wird, wird die Compileroption -optioninfer verwendet.
Festlegen der Option Infer in der IDE
Wählen Sie im Projektmappen-Explorer ein Projekt aus. Klicken Sie im Menü Projekt auf Eigenschaften.
Klicken Sie auf die Registerkarte Kompilieren.
Legen Sie den Wert im Feld Option infer fest.
Wenn Sie ein neues Projekt erstellen, ist die Einstellung Option Infer auf der Registerkarte Kompilieren auf die Einstellung Option Infer im Dialogfeld VB Defaults (VB-Standardwerte) festgelegt. Klicken Sie zum Zugriff auf das Dialogfeld VB Defaults im Menü Extras auf Optionen. Erweitern Sie im Dialogfeld OptionenProjekte und Lösungen, und klicken Sie dann auf VB Defaults. Die ursprüngliche Standardeinstellung in VB Defaults ist On
.
Festlegen der Option Infer in der Befehlszeile.
Schließen Sie die Compileroption -optioninfer in den vbc-Befehl ein.
Standarddatentypen und -werte
Die folgende Tabelle beschreibt die Ergebnisse der verschiedenen Kombinationen der Spezifizierung von Datentyp und Initialisierung in einer Dim
-Anweisung.
Datentyp angegeben? | Initialisierung angegeben? | Beispiel | Ergebnis |
---|---|---|---|
Nein | Nein | Dim qty |
Wenn Option Strict deaktiviert ist (Standard), ist die Variable auf Nothing eingestellt.Wenn Option Strict aktiviert ist, tritt ein Kompilierzeitfehler auf. |
Nein | Ja | Dim qty = 5 |
Wenn Option Infer aktiviert ist (Standard), übernimmt die Variable den Datentyp des Initialisierers an. Siehe Lokaler Typrückschluss.Wenn Option Infer und Option Strict ausgeschaltet sind, nimmt die Variable den Datentyp des Object an.Wenn Option Infer deaktiviert ist und Option Strict aktiviert ist, tritt ein Kompilierzeitfehler auf. |
Ja | Nein | Dim qty As Integer |
Die Variable wird auf den Standardwert für den Datentyp initialisiert. Weitere Informationen finden Sie unter Dim-Anweisung. |
Ja | Ja | Dim qty As Integer = 5 |
Wenn der Datentyp der Initialisierung nicht in den angegebenen Datentyp konvertiert werden kann, tritt ein Fehler während der Kompilierung auf. |
Beispiel 1
Die folgenden Beispiele veranschaulichen, wie die Option Infer
-Anweisung den lokalen Typrückschluss ermöglicht.
' Enable Option Infer before trying these examples.
' Variable num is an Integer.
Dim num = 5
' Variable dbl is a Double.
Dim dbl = 4.113
' Variable str is a String.
Dim str = "abc"
' Variable pList is an array of Process objects.
Dim pList = Process.GetProcesses()
' Variable i is an Integer.
For i = 1 To 10
Console.WriteLine(i)
Next
' Variable item is a string.
Dim lst As New List(Of String) From {"abc", "def", "ghi"}
For Each item In lst
Console.WriteLine(item)
Next
' Variable namedCust is an instance of the Customer class.
Dim namedCust = New Customer With {.Name = "Blue Yonder Airlines",
.City = "Snoqualmie"}
' Variable product is an instance of an anonymous type.
Dim product = New With {Key .Name = "paperclips", .Price = 1.29}
' If customers is a collection of Customer objects in the following
' query, the inferred type of cust is Customer, and the inferred type
' of custs is IEnumerable(Of Customer).
Dim custs = From cust In customers
Where cust.City = "Seattle"
Select cust.Name, cust.ID
Beispiel 2
Das folgende Beispiel veranschaulicht, dass der Laufzeittyp abweichen kann, wenn eine Variable als ein Object
gekennzeichnet ist.
' Disable Option Infer when trying this example.
Dim someVar = 5
Console.WriteLine(someVar.GetType.ToString)
' If Option Infer is instead enabled, the following
' statement causes a run-time error. This is because
' someVar was implicitly defined as an integer.
someVar = "abc"
Console.WriteLine(someVar.GetType.ToString)
' Output:
' System.Int32
' System.String