Operador => (Referencia de C#)=> operator (C# Reference)

El token => se admite de dos formas: como el operador lambda y como un separador de un nombre de miembro y la implementación del miembro en una definición de cuerpo de expresión.The => token is supported in two forms: as the lambda operator and as a separator of a member name and the member implementation in an expression body definition.

Operador lambdaLambda operator

En las expresiones lambda, el operador lambda => se usa para separar las variables de entrada del lado izquierdo y el cuerpo lambda del lado derecho.In lambda expressions, the lambda operator => separates the input variables on the left side from the lambda body on the right side.

En el ejemplo siguiente se usa la característica LINQ con sintaxis de método para demostrar el uso de las expresiones lambda:The following example uses the LINQ feature with method syntax to demonstrate the usage of lambda expressions:

string[] words = { "bot", "apple", "apricot" };
int minimalLength = words
  .Where(w => w.StartsWith("a"))
  .Min(w => w.Length);
Console.WriteLine(minimalLength);   // output: 5

int[] numbers = { 1, 4, 7, 10 };
int product = numbers.Aggregate(1, (interim, next) => interim * next);
Console.WriteLine(product);   // output: 280

Las variables de entrada de las expresiones lambda están fuertemente tipadas en tiempo de compilación.Input variables of lambda expressions are strongly typed at compile time. Cuando el compilador puede deducir los tipos de las variables de entrada, como en el ejemplo anterior, las declaraciones de tipos se pueden omitir.When the compiler can infer the types of input variables, like in the preceding example, you may omit type declarations. Si tiene que especificar el tipo de las variables de entrada, debe hacerlo para cada variable, como se muestra en el ejemplo siguiente:If you need to specify the type of input variables, you must do that for each variable, as the following example shows:

int[] numbers = { 1, 4, 7, 10 };
int product = numbers.Aggregate(1, (int interim, int next) => interim * next);
Console.WriteLine(product);   // output: 280

En el ejemplo siguiente se muestra cómo definir una expresión lambda sin variables de entrada:The following example shows how to define a lambda expression without input variables:

Func<string> greet = () => "Hello, World!";
Console.WriteLine(greet());

Para obtener más información, vea Expresiones lambda.For more information, see Lambda expressions.

Definición de cuerpo de expresionesExpression body definition

Una definición de cuerpo de expresión tiene la siguiente sintaxis general:An expression body definition has the following general syntax:

member => expression;

donde expresión es una expresión válida.where expression is a valid expression. Tenga en cuenta que expresión puede ser una expresión de instrucción solo si el tipo de valor devuelto del miembro es void, o bien si el miembro es un constructor, un finalizador o un descriptor de acceso set de propiedad.Note that expression can be a statement expression only if the member's return type is void, or if the member is a constructor, a finalizer, or a property set accessor.

En el ejemplo siguiente se muestra una definición de cuerpo de expresión para un método Person.ToString:The following example shows an expression body definition for a Person.ToString method:

public override string ToString() => $"{fname} {lname}".Trim();

Es una versión abreviada de la definición de método siguiente:It's a shorthand version of the following method definition:

public override string ToString()
{
   return $"{fname} {lname}".Trim();
}

A partir de C# 6, se admiten definiciones de cuerpos de expresión para métodos y propiedades de solo lectura.Expression body definitions for methods and read-only properties are supported starting with C# 6. A partir de C# 7.0, se admiten definiciones de cuerpos de expresión para constructores, finalizadores, descriptores de acceso de propiedad e indizadores.Expression body definitions for constructors, finalizers, property accessors, and indexers are supported starting with C# 7.0.

Para obtener más información, vea Miembros con forma de expresión.For more information, see Expression-bodied members.

Posibilidad de sobrecarga del operadorOperator overloadability

El operador => no se puede sobrecargar.The => operator cannot be overloaded.

Especificación del lenguaje C#C# language specification

Para obtener más información, vea la sección Expresiones de función anónima de la Especificación del lenguaje C#.For more information, see the Anonymous function expressions section of the C# language specification.

Vea tambiénSee also