Expression.Continue Metoda
Definicja
Ważne
Niektóre informacje odnoszą się do produktu w wersji wstępnej, który może zostać znacząco zmodyfikowany przed wydaniem. Firma Microsoft nie udziela żadnych gwarancji, jawnych lub domniemanych, w odniesieniu do informacji podanych w tym miejscu.
Tworzy reprezentującą instrukcję GotoExpression continue.
Przeciążenia
Continue(LabelTarget) |
Tworzy reprezentującą instrukcję GotoExpression continue. |
Continue(LabelTarget, Type) |
Tworzy reprezentującą instrukcję GotoExpression continue z określonym typem. |
Continue(LabelTarget)
- Źródło:
- GotoExpression.cs
- Źródło:
- GotoExpression.cs
- Źródło:
- GotoExpression.cs
Tworzy reprezentującą instrukcję GotoExpression continue.
public:
static System::Linq::Expressions::GotoExpression ^ Continue(System::Linq::Expressions::LabelTarget ^ target);
public static System.Linq.Expressions.GotoExpression Continue (System.Linq.Expressions.LabelTarget target);
static member Continue : System.Linq.Expressions.LabelTarget -> System.Linq.Expressions.GotoExpression
Public Shared Function Continue (target As LabelTarget) As GotoExpression
Parametry
- target
- LabelTarget
To LabelTarget , do którego GotoExpression będzie skakać.
Zwraca
Wartość równa GotoExpressionKind Kontynuuj, Target właściwość ustawiona na target
, a wartość null, która ma zostać przekazana do etykiety docelowej po skoku.
Przykłady
W poniższym przykładzie pokazano, jak utworzyć wyrażenie pętli korzystające z Continue metody .
// Add the following directive to your file:
// using System.Linq.Expressions;
// A label that is used by a break statement and a loop.
LabelTarget breakLabel = Expression.Label();
// A label that is used by the Continue statement and the loop it refers to.
LabelTarget continueLabel = Expression.Label();
// This expression represents a Continue statement.
Expression continueExpr = Expression.Continue(continueLabel);
// A variable that triggers the exit from the loop.
ParameterExpression count = Expression.Parameter(typeof(int));
// A loop statement.
Expression loopExpr = Expression.Loop(
Expression.Block(
Expression.IfThen(
Expression.GreaterThan(count, Expression.Constant(3)),
Expression.Break(breakLabel)
),
Expression.PreIncrementAssign(count),
Expression.Call(
null,
typeof(Console).GetMethod("WriteLine", new Type[] { typeof(String) }),
Expression.Constant("Loop")
),
continueExpr,
Expression.PreDecrementAssign(count)
),
breakLabel,
continueLabel
);
// The following statement first creates an expression tree,
// then compiles it, and then runs it.
// Without the Continue statement, the loop would go on forever.
Expression.Lambda<Action<int>>(loopExpr, count).Compile()(1);
// This code example produces the following output:
//
// Loop
// Loop
// Loop
' Add the following directive to your file:
' Imports System.Linq.Expressions
' A label that is used by a break statement and a loop.
Dim breakLabel As LabelTarget = Expression.Label()
' A label that is used by the Continue statement and the loop it refers to.
Dim continueLabel As LabelTarget = Expression.Label()
' This expression represents a Continue statement.
Dim continueExpr As Expression = Expression.Continue(continueLabel)
' A variable that triggers the exit from the loop.
Dim count As ParameterExpression = Expression.Parameter(GetType(Integer))
' A loop statement.
Dim loopExpr As Expression = Expression.Loop(
Expression.Block(
Expression.IfThen(
Expression.GreaterThan(count, Expression.Constant(3)),
Expression.Break(breakLabel)
),
Expression.PreIncrementAssign(count),
Expression.Call(
Nothing,
GetType(Console).GetMethod("WriteLine", New Type() {GetType(String)}),
Expression.Constant("Loop")
),
continueExpr,
Expression.PreDecrementAssign(count)
),
breakLabel,
continueLabel
)
' The following statement first creates an expression tree,
' then compiles it, and then runs it.
' Without the Continue statement, the loop would go on forever.
Expression.Lambda(Of Action(Of Integer))(loopExpr, count).Compile()(1)
' This code example produces the following output:
'
' Loop
' Loop
' Loop
Dotyczy
Continue(LabelTarget, Type)
- Źródło:
- GotoExpression.cs
- Źródło:
- GotoExpression.cs
- Źródło:
- GotoExpression.cs
Tworzy reprezentującą instrukcję GotoExpression continue z określonym typem.
public:
static System::Linq::Expressions::GotoExpression ^ Continue(System::Linq::Expressions::LabelTarget ^ target, Type ^ type);
public static System.Linq.Expressions.GotoExpression Continue (System.Linq.Expressions.LabelTarget target, Type type);
static member Continue : System.Linq.Expressions.LabelTarget * Type -> System.Linq.Expressions.GotoExpression
Public Shared Function Continue (target As LabelTarget, type As Type) As GotoExpression
Parametry
- target
- LabelTarget
To LabelTarget , do którego GotoExpression będzie skakać.
Zwraca
Element GotoExpression o Kind wartości równej Target Kontynuuj, właściwość ustawiona na target
, Type właściwość ustawiona na type
, i wartość null, która ma zostać przekazana do etykiety docelowej po skoku.