Freigeben über


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 InferOn 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:

Screenshot showing IntelliSense view when Option Infer is on.

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:

Screenshot showing IntelliSense view when Option Infer is off.

Hinweis

Wenn eine Variable als Objectdeklariert 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

  1. Wählen Sie im Projektmappen-Explorer ein Projekt aus. Klicken Sie im Menü Projekt auf Eigenschaften.

  2. Klicken Sie auf die Registerkarte Kompilieren.

  3. 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

Siehe auch