Expression.Break Método

Definição

Cria uma GotoExpression que representa uma instrução break.

Sobrecargas

Break(LabelTarget)

Cria uma GotoExpression que representa uma instrução break.

Break(LabelTarget, Expression)

Cria uma GotoExpression que representa uma instrução break. O valor passado para o rótulo no salto pode ser especificado.

Break(LabelTarget, Type)

Cria uma GotoExpression que representa uma instrução break com o tipo especificado.

Break(LabelTarget, Expression, Type)

Cria uma GotoExpression que representa uma instrução break com o tipo especificado. O valor passado para o rótulo no salto pode ser especificado.

Break(LabelTarget)

Origem:
GotoExpression.cs
Origem:
GotoExpression.cs
Origem:
GotoExpression.cs

Cria uma GotoExpression que representa uma instrução break.

C#
public static System.Linq.Expressions.GotoExpression Break (System.Linq.Expressions.LabelTarget target);

Parâmetros

target
LabelTarget

O LabelTarget para o qual o GotoExpression irá.

Retornos

Um GotoExpression com Kind igual a Break, a propriedade Target definida para target e um valor nulo a ser passado para o rótulo de destino ao saltar.

Exemplos

O exemplo a seguir demonstra como criar uma expressão que contém um LoopExpression objeto que usa o Break método .

C#
// 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

Aplica-se a

.NET 9 e outras versões
Produto Versões
.NET Core 1.0, Core 1.1, Core 2.0, Core 2.1, Core 2.2, Core 3.0, Core 3.1, 5, 6, 7, 8, 9
.NET Framework 4.0, 4.5, 4.5.1, 4.5.2, 4.6, 4.6.1, 4.6.2, 4.7, 4.7.1, 4.7.2, 4.8, 4.8.1
.NET Standard 1.0, 1.1, 1.2, 1.3, 1.4, 1.6, 2.0, 2.1
UWP 10.0

Break(LabelTarget, Expression)

Origem:
GotoExpression.cs
Origem:
GotoExpression.cs
Origem:
GotoExpression.cs

Cria uma GotoExpression que representa uma instrução break. O valor passado para o rótulo no salto pode ser especificado.

C#
public static System.Linq.Expressions.GotoExpression Break (System.Linq.Expressions.LabelTarget target, System.Linq.Expressions.Expression value);
C#
public static System.Linq.Expressions.GotoExpression Break (System.Linq.Expressions.LabelTarget target, System.Linq.Expressions.Expression? value);

Parâmetros

target
LabelTarget

O LabelTarget para o qual o GotoExpression irá.

value
Expression

O valor que será passado para o rótulo associado ao saltar.

Retornos

Um GotoExpression com Kind igual a Break, a propriedade Target definida para target e value a ser passado para o rótulo de destino ao saltar.

Aplica-se a

.NET 9 e outras versões
Produto Versões
.NET Core 1.0, Core 1.1, Core 2.0, Core 2.1, Core 2.2, Core 3.0, Core 3.1, 5, 6, 7, 8, 9
.NET Framework 4.0, 4.5, 4.5.1, 4.5.2, 4.6, 4.6.1, 4.6.2, 4.7, 4.7.1, 4.7.2, 4.8, 4.8.1
.NET Standard 1.0, 1.1, 1.2, 1.3, 1.4, 1.6, 2.0, 2.1
UWP 10.0

Break(LabelTarget, Type)

Origem:
GotoExpression.cs
Origem:
GotoExpression.cs
Origem:
GotoExpression.cs

Cria uma GotoExpression que representa uma instrução break com o tipo especificado.

C#
public static System.Linq.Expressions.GotoExpression Break (System.Linq.Expressions.LabelTarget target, Type type);

Parâmetros

target
LabelTarget

O LabelTarget para o qual o GotoExpression irá.

type
Type

Um Type para definir a propriedade Type igual a ele.

Retornos

Um GotoExpression com Kind igual a Break, a propriedade Target definida para target e a propriedade Type definida para type.

Aplica-se a

.NET 9 e outras versões
Produto Versões
.NET Core 1.0, Core 1.1, Core 2.0, Core 2.1, Core 2.2, Core 3.0, Core 3.1, 5, 6, 7, 8, 9
.NET Framework 4.0, 4.5, 4.5.1, 4.5.2, 4.6, 4.6.1, 4.6.2, 4.7, 4.7.1, 4.7.2, 4.8, 4.8.1
.NET Standard 1.0, 1.1, 1.2, 1.3, 1.4, 1.6, 2.0, 2.1
UWP 10.0

Break(LabelTarget, Expression, Type)

Origem:
GotoExpression.cs
Origem:
GotoExpression.cs
Origem:
GotoExpression.cs

Cria uma GotoExpression que representa uma instrução break com o tipo especificado. O valor passado para o rótulo no salto pode ser especificado.

C#
public static System.Linq.Expressions.GotoExpression Break (System.Linq.Expressions.LabelTarget target, System.Linq.Expressions.Expression value, Type type);
C#
public static System.Linq.Expressions.GotoExpression Break (System.Linq.Expressions.LabelTarget target, System.Linq.Expressions.Expression? value, Type type);

Parâmetros

target
LabelTarget

O LabelTarget para o qual o GotoExpression irá.

value
Expression

O valor que será passado para o rótulo associado ao saltar.

type
Type

Um Type para definir a propriedade Type igual a ele.

Retornos

Um GotoExpression com Kind igual a Break, a propriedade Target definida para target, a propriedade Type definida para type e value a serem passados para o rótulo de destino após saltar.

Aplica-se a

.NET 9 e outras versões
Produto Versões
.NET Core 1.0, Core 1.1, Core 2.0, Core 2.1, Core 2.2, Core 3.0, Core 3.1, 5, 6, 7, 8, 9
.NET Framework 4.0, 4.5, 4.5.1, 4.5.2, 4.6, 4.6.1, 4.6.2, 4.7, 4.7.1, 4.7.2, 4.8, 4.8.1
.NET Standard 1.0, 1.1, 1.2, 1.3, 1.4, 1.6, 2.0, 2.1
UWP 10.0