Expression.Label Methode

Definition

Erstellt eine LabelTarget Beschriftung.

Überlädt

Name Beschreibung
Label()

Erstellt eine LabelTarget Beschriftung mit leerem Typ und keinem Namen.

Label(LabelTarget)

Erstellt eine Darstellung einer LabelExpression Beschriftung ohne Standardwert.

Label(String)

Erstellt eine Darstellung einer LabelTarget Beschriftung mit leerem Typ und dem angegebenen Namen.

Label(Type)

Erstellt eine Darstellung einer LabelTarget Beschriftung mit dem angegebenen Typ.

Label(LabelTarget, Expression)

Erstellt eine Darstellung einer LabelExpression Beschriftung mit dem angegebenen Standardwert.

Label(Type, String)

Erstellt eine Darstellung einer LabelTarget Beschriftung mit dem angegebenen Typ und Namen.

Label()

Erstellt eine LabelTarget Beschriftung mit leerem Typ und keinem Namen.

public:
 static System::Linq::Expressions::LabelTarget ^ Label();
public static System.Linq.Expressions.LabelTarget Label();
static member Label : unit -> System.Linq.Expressions.LabelTarget
Public Shared Function Label () As LabelTarget

Gibt zurück

Die neue LabelTarget.

Beispiele

Das folgende Beispiel veranschaulicht das Erstellen eines Ausdrucks, der ein LabelTarget Objekt enthält.

// Add the following directive to the file:
// using System.Linq.Expressions;

// A label expression of the void type that is the target for Expression.Return().
LabelTarget returnTarget = Expression.Label();

// This block contains a GotoExpression that represents a return statement with no value.
// It transfers execution to a label expression that is initialized with the same LabelTarget as the GotoExpression.
// The types of the GotoExpression, label expression, and LabelTarget must match.
BlockExpression blockExpr =
    Expression.Block(
        Expression.Call(typeof(Console).GetMethod("WriteLine", new Type[] { typeof(string) }), Expression.Constant("Return")),
        Expression.Return(returnTarget),
        Expression.Call(typeof(Console).GetMethod("WriteLine", new Type[] { typeof(string) }), Expression.Constant("Other Work")),
        Expression.Label(returnTarget)
    );

// The following statement first creates an expression tree,
// then compiles it, and then runs it.
Expression.Lambda<Action>(blockExpr).Compile()();

// This code example produces the following output:
//
// Return

// "Other Work" is not printed because
// the Return expression transfers execution from Expression.Return(returnTarget)
// to Expression.Label(returnTarget).
' Add the following directive to the file:
' Imports System.Linq.Expressions  

' A label expression of the void type that is the target for Expression.Return().
Dim returnTarget As LabelTarget = Expression.Label()

' This block contains a GotoExpression that represents a return statement with no value.
' It transfers execution to a label expression that is initialized with the same LabelTarget as the GotoExpression.
' The types of the GotoExpression, label expression, and LabelTarget must match.
Dim blockExpr As BlockExpression =
      Expression.Block(
          Expression.Call(GetType(Console).GetMethod("WriteLine", New Type() {GetType(String)}), Expression.Constant("Return")),
          Expression.Return(returnTarget),
          Expression.Call(GetType(Console).GetMethod("WriteLine", New Type() {GetType(String)}), Expression.Constant("Other Work")),
          Expression.Label(returnTarget)
      )

' The following statement first creates an expression tree,
' then compiles it, and then runs it.
Expression.Lambda(Of Action)(blockExpr).Compile()()

' This code example produces the following output:
'
' Return

' "Other Work" is not printed because 
' the Return expression transfers execution from Return(returnTarget)
' to Expression.Label(returnTarget).

Gilt für:

Label(LabelTarget)

Erstellt eine Darstellung einer LabelExpression Beschriftung ohne Standardwert.

public:
 static System::Linq::Expressions::LabelExpression ^ Label(System::Linq::Expressions::LabelTarget ^ target);
public static System.Linq.Expressions.LabelExpression Label(System.Linq.Expressions.LabelTarget target);
static member Label : System.Linq.Expressions.LabelTarget -> System.Linq.Expressions.LabelExpression
Public Shared Function Label (target As LabelTarget) As LabelExpression

Parameter

target
LabelTarget

Dies LabelTargetLabelExpression wird zugeordnet.

Gibt zurück

A LabelExpression ohne Standardwert.

Gilt für:

Label(String)

Erstellt eine Darstellung einer LabelTarget Beschriftung mit leerem Typ und dem angegebenen Namen.

public:
 static System::Linq::Expressions::LabelTarget ^ Label(System::String ^ name);
public static System.Linq.Expressions.LabelTarget Label(string name);
static member Label : string -> System.Linq.Expressions.LabelTarget
Public Shared Function Label (name As String) As LabelTarget

Parameter

name
String

Der Name der Bezeichnung.

Gibt zurück

Die neue LabelTarget.

Gilt für:

Label(Type)

Erstellt eine Darstellung einer LabelTarget Beschriftung mit dem angegebenen Typ.

public:
 static System::Linq::Expressions::LabelTarget ^ Label(Type ^ type);
public static System.Linq.Expressions.LabelTarget Label(Type type);
static member Label : Type -> System.Linq.Expressions.LabelTarget
Public Shared Function Label (type As Type) As LabelTarget

Parameter

type
Type

Der Typ des Werts, der beim Springen zur Beschriftung übergeben wird.

Gibt zurück

Die neue LabelTarget.

Beispiele

Im folgenden Beispiel wird die Verwendung eines LabelTarget Objekts in einem Schleifenausdruck veranschaulicht.

// Add the following directive to the file:
// using System.Linq.Expressions;

// Creating a parameter expression.
ParameterExpression value = Expression.Parameter(typeof(int), "value");

// Creating an expression to hold a local variable.
ParameterExpression result = Expression.Parameter(typeof(int), "result");

// Creating a label to jump to from a loop.
LabelTarget label = Expression.Label(typeof(int));

// Creating a method body.
BlockExpression block = Expression.Block(
    new[] { result },
    Expression.Assign(result, Expression.Constant(1)),
        Expression.Loop(
           Expression.IfThenElse(
               Expression.GreaterThan(value, Expression.Constant(1)),
               Expression.MultiplyAssign(result,
                   Expression.PostDecrementAssign(value)),
               Expression.Break(label, result)
           ),
       label
    )
);

// Compile and run an expression tree.
int factorial = Expression.Lambda<Func<int, int>>(block, value).Compile()(5);

Console.WriteLine(factorial);

// This code example produces the following output:
//
// 120
' Add the following directive to the file:
' Imports System.Linq.Expressions  

' Creating a parameter expression.
Dim value As ParameterExpression =
    Expression.Parameter(GetType(Integer), "value")

' Creating an expression to hold a local variable. 
Dim result As ParameterExpression =
    Expression.Parameter(GetType(Integer), "result")

' Creating a label to jump to from a loop.
Dim label As LabelTarget = Expression.Label(GetType(Integer))

' Creating a method body.
Dim block As BlockExpression = Expression.Block(
    New ParameterExpression() {result},
    Expression.Assign(result, Expression.Constant(1)),
    Expression.Loop(
        Expression.IfThenElse(
            Expression.GreaterThan(value, Expression.Constant(1)),
            Expression.MultiplyAssign(result,
                Expression.PostDecrementAssign(value)),
            Expression.Break(label, result)
        ),
        label
    )
)

' Compile an expression tree and return a delegate.
Dim factorial As Integer =
    Expression.Lambda(Of Func(Of Integer, Integer))(block, value).Compile()(5)

Console.WriteLine(factorial)

' This code example produces the following output:
'
' 120

Gilt für:

Label(LabelTarget, Expression)

Erstellt eine Darstellung einer LabelExpression Beschriftung mit dem angegebenen Standardwert.

public:
 static System::Linq::Expressions::LabelExpression ^ Label(System::Linq::Expressions::LabelTarget ^ target, System::Linq::Expressions::Expression ^ defaultValue);
public static System.Linq.Expressions.LabelExpression Label(System.Linq.Expressions.LabelTarget target, System.Linq.Expressions.Expression defaultValue);
static member Label : System.Linq.Expressions.LabelTarget * System.Linq.Expressions.Expression -> System.Linq.Expressions.LabelExpression
Public Shared Function Label (target As LabelTarget, defaultValue As Expression) As LabelExpression

Parameter

target
LabelTarget

Dies LabelTargetLabelExpression wird zugeordnet.

defaultValue
Expression

Der Wert dieses Werts LabelExpression , wenn die Beschriftung über einen regulären Kontrollfluss erreicht wird.

Gibt zurück

A LabelExpression mit dem angegebenen Standardwert.

Gilt für:

Label(Type, String)

Erstellt eine Darstellung einer LabelTarget Beschriftung mit dem angegebenen Typ und Namen.

public:
 static System::Linq::Expressions::LabelTarget ^ Label(Type ^ type, System::String ^ name);
public static System.Linq.Expressions.LabelTarget Label(Type type, string name);
static member Label : Type * string -> System.Linq.Expressions.LabelTarget
Public Shared Function Label (type As Type, name As String) As LabelTarget

Parameter

type
Type

Der Typ des Werts, der beim Springen zur Beschriftung übergeben wird.

name
String

Der Name der Bezeichnung.

Gibt zurück

Die neue LabelTarget.

Gilt für: