Notitie
Voor toegang tot deze pagina is autorisatie vereist. U kunt proberen u aan te melden of de directory te wijzigen.
Voor toegang tot deze pagina is autorisatie vereist. U kunt proberen de mappen te wijzigen.
De operator Lambda-expressie (
Het => token wordt in twee vormen ondersteund: als de lambda-operator en als scheidingsteken van een lidnaam en de implementatie van het lid in een definitie van de expressietekst.
De C#-taalreferentiedocumenten beschrijven de meest recent uitgebrachte versie van de C#-taal. Het bevat ook de eerste documentatie voor functies in openbare previews voor de aanstaande taalrelease.
De documentatie identificeert alle functies die voor het eerst zijn geïntroduceerd in de laatste drie versies van de taal of in de huidige openbare previews.
Aanbeveling
Raadpleeg het artikel over de versiegeschiedenis van de C#-taal om te achterhalen wanneer een functie voor het eerst is geïntroduceerd in C#.
Lambda-operator
In lambda-expressies scheidt de lambda-operator => de invoerparameters aan de linkerkant van de lambda-body aan de rechterkant.
In het volgende voorbeeld wordt de LINQ-functie met methodesyntaxis gebruikt om het gebruik van lambda-expressies te demonstreren:
string[] words = { "bot", "apple", "apricot" };
int minimalLength = words
.Where(w => w.StartsWith("a"))
.Min(w => w.Length);
Console.WriteLine(minimalLength); // output: 5
int[] numbers = { 4, 7, 10 };
int product = numbers.Aggregate(1, (interim, next) => interim * next);
Console.WriteLine(product); // output: 280
Invoerparameters van een lambda-expressie worden sterk getypt tijdens het compileren. Wanneer de compiler de typen invoerparameters afgeeft, zoals in het vorige voorbeeld, kunt u typedeclaraties weglaten. Als u het type invoerparameters moet opgeven, moet u het type voor elke parameter opgeven, zoals in het volgende voorbeeld wordt weergegeven:
int[] numbers = { 4, 7, 10 };
int product = numbers.Aggregate(1, (int interim, int next) => interim * next);
Console.WriteLine(product); // output: 280
In het volgende voorbeeld ziet u hoe u een lambda-expressie zonder invoerparameters definieert:
Func<string> greet = () => "Hello, World!";
Console.WriteLine(greet());
Zie Lambda-expressies voor meer informatie.
Hoofdtekstdefinitie van expressie
Een definitie van de hoofdtekst van een expressie maakt gebruik van de volgende algemene syntaxis:
member => expression;
Dit expression is een geldige expressie. Het retourtype expression moet impliciet worden omgezet in het retourtype van het lid. Als het lid:
- Heeft een
voidretourtype, of - Is een:
- Constructeur
- Eindschutter
- Accessor voor eigenschappen of indexeerfuncties
set
expression moet een instructieexpressie zijn. Omdat het resultaat van de expressie wordt verwijderd, kan het retourtype van die expressie elk type zijn.
In het volgende voorbeeld ziet u een definitie van de hoofdtekst van een expressie voor een Person.ToString methode:
public override string ToString() => $"{fname} {lname}".Trim();
Het is een verkorte versie van de volgende methodedefinitie:
public override string ToString()
{
return $"{fname} {lname}".Trim();
}
U kunt hoofdtekstdefinities voor expressies maken voor methoden, operators, alleen-lezeneigenschappen, constructors, finalizers en eigenschaps- en indexeerfuncties. Zie Expressie-lichaamsleden voor meer informatie.
Overbelasting van operatoren
U kunt de => operator niet overbelasten.
C#-taalspecificatie
Zie de sectie Anonieme functie-expressies van de C#-taalspecificatie voor meer informatie over de lambda-operator.