Anonyme Funktion
Eine anonyme Funktion (auch Funktionsliteral, Lambda-Funktion oder Lambda-Ausdruck) ist eine Funktionsdefinition, die nicht an einen Bezeichner gebunden ist. Anonyme Funktionen werden häufig als Argumente an Funktionen höherer Ordnung übergeben oder zum Erstellen des Ergebnisses einer Funktion höherer Ordnung verwendet, die eine Funktion zurückgeben muss. Wenn eine Funktion nur an einer Stelle verwendet wird und einen begrenzten Umfang hat, kann eine anonyme Funktion syntaktisch einfacher sein als die Verwendung einer benannten Funktion. Anonyme Funktionen sind in funktionalen Programmiersprachen und anderen Sprachen mit First-Class-Funktionen allgegenwärtig, wo sie für den Funktionstyp dieselbe Rolle erfüllen wie Literale für andere Datentypen.
Anonyme Funktionen wurden ursprünglich von Alonzo Church mit seiner Erfindung des Lambda-Kalküls im Jahr 1936 geprägt, in dem alle Funktionen anonym sind. Anonyme Funktionen sind seit Lisp im Jahr 1958 ein Merkmal von Programmiersprachen, und eine wachsende Anzahl moderner Programmiersprachen unterstützt anonyme Funktionen.
Benannte Funktionen
Im Gegensatz zu einer anonymen Funktion erhält eine benannte Funktionen bei ihrer Deklaration einen eindeutigen Bezeichner, unter dem sie anschließend angesprochen wird. Der Name der Funktion wird vom Compiler oder vom Laufzeitsystem dazu verwendet, mit Hilfe der Symboltabelle oder eines dynamischen Verfahrens die Funktionsdefinition zu identifizieren und dort hinterlegten Code auszuführen.
Beispiel in JavaScript
<syntaxhighlight lang="javascript"> function Bezeichner_meiner_Funktion() {
console.log("Hallo, Welt!");
}
Bezeichner_meiner_Funktion(); </syntaxhighlight>
Beispiele
Common Lisp
Die folgende Funktion verdoppelt ihr Argument:
<syntaxhighlight lang="common-lisp"> (lambda (x) (* x 2)) </syntaxhighlight>
Um diese Funktion im selben Zug zu verwenden, kann die Funktion direkt auf ein Argument angewendet werden:
<syntaxhighlight lang="common-lisp"> (funcall (lambda (x) (* x 2)) 5) </syntaxhighlight>
Der Wert dieses Ausdrucks ist 10.
Das nächste Beispiel definiert eine Funktion höherer Ordnung und nennt sie meinFilter. Das erste Argument dieser Funktion ist eine weitere Funktion. Im unteren Teil des Beispiels wird für dieses Argument der lambda-Ausdruck angegeben.
<syntaxhighlight lang="common-lisp"> (defun meinFilter (eigenschaft liste)
(cond ((null liste) nil)
((if (funcall eigenschaft (car liste))
(cons (car liste) (meinFilter eigenschaft (cdr liste)))
(meinFilter eigenschaft (cdr liste))))))
(meinFilter (lambda (wert) (= (mod wert 2) 0)) '(0 1 2 3 4 5 6 7 8 9)))
</syntaxhighlight> Das Ergebnis der Berechnung ist <syntaxhighlight lang="common-lisp"> (0 2 4 6 8) </syntaxhighlight>
C++
Lambda-Ausdrücke bieten semantisch ähnliche Möglichkeiten wie das verwandte Konzept der Funktionszeiger. In C++ können anonyme Funktionen folgendermaßen definiert werden:
[capture]<template>(parameter) -> type { body }
- capture: Übertrag der angegebenen Symbole in den Gültigkeitsbereich des Lambda-Ausdrucks
- template: Liste der Templateparameter (ab C++20)
- parameter: Liste der Übergabeparameter
- type: Rückgabetyp
- body: Funktionsrumpf
<syntaxhighlight lang="cpp">
- include <functional>
- include <iostream>
- include <vector>
using namespace std;
vector<int> meinFilter(function<bool(int)> eigenschaft, const vector<int> &liste) {
auto sieb = vector<int>(); sieb.reserve(liste.size());
for (int element: liste)
if (eigenschaft(element))
sieb.push_back(element);
return sieb;
}
int main() {
vector<int> liste = {0, 1, 2, 3, 4, 5, 6, 7, 8, 9};
auto sieb = meinFilter([](int wert) { return wert % 2 == 0; }, liste);
for (int element: sieb)
cout << element << " ";
return 0;
} </syntaxhighlight>
C#
<syntaxhighlight lang="c#"> using System; using System.Collections.Generic;
delegate bool Funktion(int wert);
class Programm {
static List<int> meinFilter(Funktion eigenschaft, List<int> liste) {
var sieb = new List<int>();
sieb.Capacity = liste.Count;
foreach (var element in liste)
if (eigenschaft(element))
sieb.Add(element);
return sieb; }
public static void Main(string[] args) {
var liste = new List<int>() {0, 1, 2, 3, 4, 5, 6, 7, 8, 9};
var sieb = meinFilter(wert => wert % 2 == 0, liste);
foreach (int element in sieb)
Console.Write(element + " ");
}
} </syntaxhighlight>
Haskell
<syntaxhighlight lang="haskell"> meinFilter eigenschaft liste = [element | element <- liste, eigenschaft element]
main = print $ meinFilter (\wert -> mod wert 2 == 0) [0..9] </syntaxhighlight>
Java
In Java mussten für diesen Zweck früher anonyme innere Klassen<ref name="Java Insel 9, 8.1.4"/> verwendet werden. Ab Version 8 stehen sogenannte Lambda-Ausdrücke zur Verfügung.<ref name="EffectiveJava 8"/>
<syntaxhighlight lang="java"> import java.util.ArrayList; import java.util.Arrays; import java.util.function.IntPredicate; import java.util.List;
class Main {
static List<Integer> meinFilter(IntPredicate eigenschaft, List<Integer> liste) {
var sieb = new ArrayList<Integer>();
for (Integer element: liste)
if (eigenschaft.test(element))
sieb.add(element);
return sieb; }
public static void main(String[] args) {
var liste = Arrays.asList(0, 1, 2, 3, 4, 5, 6, 7, 8, 9);
var sieb = meinFilter(wert -> wert % 2 == 0, liste);
for (var element: sieb)
System.out.print(element + " ");
}
} </syntaxhighlight>
JavaScript
<syntaxhighlight lang="javascript"> function meinFilter(eigenschaft, liste) {
let sieb = [];
for (let element of liste)
if (eigenschaft(element))
sieb.push(element);
return sieb;
}
let liste = [0, 1, 2, 3, 4, 5, 6, 7, 8, 9]; console.log(meinFilter(wert => wert % 2 == 0, liste)); </syntaxhighlight>
Python
<syntaxhighlight lang="python3"> def meinFilter(eigenschaft, liste):
sieb = []
for element in liste:
if eigenschaft(element):
sieb.append(element)
return sieb
liste = [0, 1, 2, 3, 4, 5, 6, 7, 8, 9] print(meinFilter(lambda wert: wert % 2 == 0, liste)) </syntaxhighlight>
Einzelnachweise
<references> <ref name="Java Insel 9, 8.1.4">{{#invoke:Vorlage:Literatur|f}} </ref> <ref name="EffectiveJava 8">{{#if:|{{#iferror: {{#iferror:{{#invoke:Vorlage:FormatDate|Execute}}|}}| |}}}}{{#if:Angelika Langer|Angelika Langer: }}{{#if:|{{#if:Lambda-Ausdrücke und Methoden-Referenzen|[{{#invoke:Vorlage:Internetquelle|archivURL|1={{#invoke:URLutil|getNormalized|1={{{archiv-url}}}}}}} {{#invoke:Vorlage:Internetquelle|TitelFormat|titel=Lambda-Ausdrücke und Methoden-Referenzen}}]{{#if:| ({{{format}}})}}{{#if:| {{{titelerg}}}{{#invoke:Vorlage:Internetquelle|Endpunkt|titel={{{titelerg}}}}}}}}}|{{#if:https://www.angelikalanger.com/Articles/EffectiveJava/71.Java8.Lambdas/71.Java8.Lambdas.html%7C{{#if:{{#invoke:TemplUtl%7Cfaculty%7C}}%7C{{#invoke:Vorlage:Internetquelle%7CTitelFormat%7Ctitel={{#invoke:WLink%7CgetEscapedTitle%7C1=Lambda-Ausdrücke und Methoden-Referenzen}}}}|[{{#invoke:URLutil|getNormalized|1=https://www.angelikalanger.com/Articles/EffectiveJava/71.Java8.Lambdas/71.Java8.Lambdas.html}} {{#invoke:Vorlage:Internetquelle|TitelFormat|titel={{#invoke:WLink|getEscapedTitle|1=Lambda-Ausdrücke und Methoden-Referenzen}}}}]}}{{#if:| ({{{format}}}{{#if:2013-11{{#if: 2020-04-17 | {{#if:{{#invoke:TemplUtl|faculty|}}||1}}}}
| )
| {{#if:{{#ifeq:de|de||{{#if:|1}}}}| ;
| )}}}}}}{{#if:| {{{titelerg}}}{{#invoke:Vorlage:Internetquelle|Endpunkt|titel={{{titelerg}}}}}}}}}}}{{#if:https://www.angelikalanger.com/Articles/EffectiveJava/71.Java8.Lambdas/71.Java8.Lambdas.html%7C{{#if:{{#invoke:URLutil%7CisResourceURL%7C1=https://www.angelikalanger.com/Articles/EffectiveJava/71.Java8.Lambdas/71.Java8.Lambdas.html}}%7C%7C}}}}{{#if:Lambda-Ausdrücke und Methoden-Referenzen|{{#if:{{#invoke:WLink|isValidLinktext|1=Lambda-Ausdrücke und Methoden-Referenzen|lines=0}}||}}}}{{#if: | In: {{#invoke:Vorlage:Internetquelle|TitelFormat|titel=}}}}{{#if: | {{#if: 2013-11|,|{{#if: 2020-04-17 | {{#if:{{#invoke:TemplUtl|faculty|}}||,}}}}}}}}{{#if: 2013-11| {{#if:{{#invoke:DateTime|format|2013-11|noerror=1}}
|{{#invoke:DateTime|format|2013-11|T._Monat JJJJ}}
|{{#invoke:TemplUtl|failure|1=Fehler bei Vorlage:Internetquelle, datum=2013-11|class=Zitationswartung}} }}{{#if: |,|{{#if: 2020-04-17 | {{#if:{{#invoke:TemplUtl|faculty|}}||,}}}}}}}}{{#if: | S. {{{seiten}}}{{#if: |,|{{#if: 2020-04-17 | {{#if:{{#invoke:TemplUtl|faculty|}}||,}}}}}}}}{{#if: {{#invoke:TemplUtl|faculty|}}| {{#if:2013-11|{{#if:|archiviert|ehemals}}|{{#if:|Archiviert|Ehemals}}}} {{#if:|vom|im}} Vorlage:Referrer{{#if:{{#invoke:TemplUtl|faculty|}}| (nicht mehr online verfügbar)}}{{#if: | am {{#iferror: {{#iferror:{{#invoke:Vorlage:FormatDate|Execute}}|}}|{{{archiv-datum}}}{{#if:147666||(?)}}}}}}{{#if: 2020-04-17|;}}}}{{#if: 2020-04-17| {{#if:2013-11{{#invoke:TemplUtl|faculty|}}|abgerufen|Abgerufen}} {{#switch: {{#invoke:Str|len| {{#invoke:DateTime|format| 2020-04-17 |ISO|noerror=1}} }}
|4=im Jahr
|7=im
|10=am
|#default={{#invoke:TemplUtl|failure|1=Fehler bei Vorlage:Internetquelle, abruf=2020-04-17|class=Zitationswartung}} }} {{#invoke:DateTime|format|2020-04-17|T._Monat JJJJ}}
| {{#invoke:TemplUtl|failure|1=Vorlage:Internetquelle | abruf=2026-MM-TT ist Pflichtparameter}} }}{{#if:{{#ifeq:de|de||{{#if:|1}}}}|{{#if:2013-11{{#if: 2020-04-17 | {{#if:{{#invoke:TemplUtl|faculty|}}||1}}}}
| (
| {{#if: | | (}}
}}{{#ifeq:{{#if:de|de|de}}|de||
{{#invoke:Multilingual|format|{{{sprache}}}|slang=!|split=[%s,]+|shift=m|separator=, }}}}{{#if: |{{#ifeq:{{#if:de|de|de}}|de||, }}{{{kommentar}}}}})}}{{#if: 2013-11{{#if: 2020-04-17 | {{#if:{{#invoke:TemplUtl|faculty|}}||1}} }}|{{#if: |: {{
#if:
| „{{
#ifeq: {{#if:{{#if: {{#invoke:templutl|faculty|}}|de-ch|de}}|{{#if: {{#invoke:templutl|faculty|}}|de-ch|de}}|de}} | de
| Vorlage:Str trim
| {{#invoke:Vorlage:lang|flat}}
}}“
| {{#ifeq: {{#if:{{#if: {{#invoke:templutl|faculty|}}|de-ch|de}}|{{#if: {{#invoke:templutl|faculty|}}|de-ch|de}}|de}} | de
| „Vorlage:Str trim“
| {{#invoke:Text|quote
|1={{#if:
| {{#invoke:Vorlage:lang|flat}}
| {{#invoke:Vorlage:lang|flat}} }}
|2={{#if: {{#invoke:TemplUtl|faculty|}}|de-CH|de}}
|3=1}} }}
}}{{#if:
| (<templatestyles src="Person/styles.css" />{{#if: | : }}{{#if: | , deutsch: „“ }})
| {{#if:
| ({{#if: | , deutsch: „“ }})
| {{#if: | (deutsch: „“) }}
}}
}}{{#if: {{{zitat}}}
| {{#if:
| {{#if: {{{zitat}}}
| Vorlage:": Text= und 1= gleichzeitig, bzw. Pipe zu viel }} }}
| Vorlage:": Text= fehlt }}{{#if: | {{#if: {{#invoke:Text|unstrip|{{{ref}}}}}
| Vorlage:": Ungültiger Wert: ref=
| {{{ref}}} }}
}}|.{{#if:{{#invoke:TemplUtl|faculty|}}|{{#if:||{{#ifeq: | JaKeinHinweis |{{#switch:
|0|=Vorlage:Toter Link/Core{{#if: https://www.angelikalanger.com/Articles/EffectiveJava/71.Java8.Lambdas/71.Java8.Lambdas.html | {{#if: | [1] }} (Seite {{#switch:|no|0|=|dauerhaft }}nicht mehr abrufbar{{#if: | , festgestellt im {{#invoke:DateTime|format||F Y}} }}. Suche im Internet Archive ){{#if: | {{#if: deadurlausgeblendet | | Vorlage:Toter Link/archivebot }} }} | (Seite {{#switch:|no|0|=|#default=dauerhaft }}nicht mehr abrufbar{{#if: | , festgestellt im {{#invoke:DateTime|format||F Y}} }}.) }}{{#switch: |no|0|= |#default={{#if: || }} }}{{#invoke:TemplatePar|check |opt = inline= url= text= datum= date= archivebot= bot= botlauf= fix-attempted= checked= |cat = Wikipedia:Vorlagenfehler/Vorlage:Toter Link |errNS = 0 |template = Vorlage:Toter Link |format = |preview = 1 }}{{#if: https://www.angelikalanger.com/Articles/EffectiveJava/71.Java8.Lambdas/71.Java8.Lambdas.html | {{#if:{{#invoke:URLutil|isWebURL|https://www.angelikalanger.com/Articles/EffectiveJava/71.Java8.Lambdas/71.Java8.Lambdas.html}} || {{#if: || }} }} | {{#if: | {{#if: || }} | {{#if: || }} }} }}{{#if: | {{#if:{{#invoke:DateTime|format||F Y|noerror=1}} || {{#if: || }} }} }}{{#switch: deadurl |checked|deadurl|= |#default= {{#if: || }} }}|#default= https://wiki-de.moshellshocker.dns64.de/index.php?title=Wikipedia:Defekte_Weblinks&dwl=https://www.angelikalanger.com/Articles/EffectiveJava/71.Java8.Lambdas/71.Java8.Lambdas.html Die nachstehende Seite ist {{#switch:|no|0|=|dauerhaft }}nicht mehr abrufbar]{{#if: | , festgestellt im {{#invoke:DateTime|format||F Y}} }}. (Suche im Internet Archive. ) {{#if: | {{#if: deadurlausgeblendet | | Vorlage:Toter Link/archivebot }} }}Vorlage:Toter Link/Core{{#switch: |no|0|= |#default= {{#if: || }} }}{{#invoke:TemplatePar|check |all = inline= url= |opt = datum= date= archivebot= bot= botlauf= fix-attempted= checked= |cat = Wikipedia:Vorlagenfehler/Vorlage:Toter Link |errNS = 0 |template = Vorlage:Toter Link |format = |preview = 1 }}{{#if: https://www.angelikalanger.com/Articles/EffectiveJava/71.Java8.Lambdas/71.Java8.Lambdas.html | {{#if:{{#invoke:URLutil|isWebURL|https://www.angelikalanger.com/Articles/EffectiveJava/71.Java8.Lambdas/71.Java8.Lambdas.html}} || {{#if: || }} }} }}{{#if: | {{#if:{{#invoke:DateTime|format||F Y|noerror=1}} || {{#if: || }} }} }}{{#switch: deadurl |checked|deadurl|= |#default= {{#if: || }} }}[https://www.angelikalanger.com/Articles/EffectiveJava/71.Java8.Lambdas/71.Java8.Lambdas.html }}|{{#switch: |0|=Vorlage:Toter Link/Core{{#if: https://www.angelikalanger.com/Articles/EffectiveJava/71.Java8.Lambdas/71.Java8.Lambdas.html | {{#if: | [2] }} (Seite {{#switch:|no|0|=|dauerhaft }}nicht mehr abrufbar{{#if: | , festgestellt im {{#invoke:DateTime|format||F Y}} }}. Suche im Internet Archive ){{#if: | {{#if: | | Vorlage:Toter Link/archivebot }} }} | (Seite {{#switch:|no|0|=|#default=dauerhaft }}nicht mehr abrufbar{{#if: | , festgestellt im {{#invoke:DateTime|format||F Y}} }}.) }}{{#switch: |no|0|= |#default={{#if: || }} }}{{#invoke:TemplatePar|check |opt = inline= url= text= datum= date= archivebot= bot= botlauf= fix-attempted= checked= |cat = Wikipedia:Vorlagenfehler/Vorlage:Toter Link |errNS = 0 |template = Vorlage:Toter Link |format = |preview = 1 }}{{#if: https://www.angelikalanger.com/Articles/EffectiveJava/71.Java8.Lambdas/71.Java8.Lambdas.html | {{#if:{{#invoke:URLutil|isWebURL|https://www.angelikalanger.com/Articles/EffectiveJava/71.Java8.Lambdas/71.Java8.Lambdas.html}} || {{#if: || }} }} | {{#if: | {{#if: || }} | {{#if: || }} }} }}{{#if: | {{#if:{{#invoke:DateTime|format||F Y|noerror=1}} || {{#if: || }} }} }}{{#switch: |checked|deadurl|= |#default= {{#if: || }} }}|#default= https://wiki-de.moshellshocker.dns64.de/index.php?title=Wikipedia:Defekte_Weblinks&dwl=https://www.angelikalanger.com/Articles/EffectiveJava/71.Java8.Lambdas/71.Java8.Lambdas.html Die nachstehende Seite ist {{#switch:|no|0|=|dauerhaft }}nicht mehr abrufbar]{{#if: | , festgestellt im {{#invoke:DateTime|format||F Y}} }}. (Suche im Internet Archive. ) {{#if: | {{#if: | | Vorlage:Toter Link/archivebot }} }}Vorlage:Toter Link/Core{{#switch: |no|0|= |#default= {{#if: || }} }}{{#invoke:TemplatePar|check |all = inline= url= |opt = datum= date= archivebot= bot= botlauf= fix-attempted= checked= |cat = Wikipedia:Vorlagenfehler/Vorlage:Toter Link |errNS = 0 |template = Vorlage:Toter Link |format = |preview = 1 }}{{#if: https://www.angelikalanger.com/Articles/EffectiveJava/71.Java8.Lambdas/71.Java8.Lambdas.html | {{#if:{{#invoke:URLutil|isWebURL|https://www.angelikalanger.com/Articles/EffectiveJava/71.Java8.Lambdas/71.Java8.Lambdas.html}} || {{#if: || }} }} }}{{#if: | {{#if:{{#invoke:DateTime|format||F Y|noerror=1}} || {{#if: || }} }} }}{{#switch: |checked|deadurl|= |#default= {{#if: || }} }}[https://www.angelikalanger.com/Articles/EffectiveJava/71.Java8.Lambdas/71.Java8.Lambdas.html }} }}}}}}}}}}{{#if:| {{#invoke:Vorlage:Internetquelle|archivBot|stamp={{{archiv-bot}}}|text={{#if:|Vorlage:Webarchiv/archiv-bot}}
}}}}{{#invoke:TemplatePar|check |all= url= titel= |opt= autor= hrsg= format= sprache= titelerg= werk= seiten= datum= abruf= zugriff= abruf-verborgen= archiv-url= archiv-datum= archiv-bot= kommentar= zitat= AT= CH= offline= |cat= {{#ifeq: 0 | 0 | Wikipedia:Vorlagenfehler/Vorlage:Internetquelle}} |template= Vorlage:Internetquelle |format=0 |preview=1 }} </ref> </references>
- Wikipedia:Vorlagenfehler/Parameter:URL
- Wikipedia:Vorlagenfehler/Parameter:Linktext
- Wikipedia:Vorlagenfehler/Parameter:Datum
- Wikipedia:Vorlagenfehler/Vorlage:"
- Wikipedia:Weblink offline fix-attempted
- Wikipedia:Vorlagenfehler/Vorlage:Toter Link
- Wikipedia:Vorlagenfehler/Vorlage:Toter Link/URL fehlt
- Compilerbau
- Programmiersprachelement