Kompilierungsprobleme mit rekursiven Lambda-Funktionen lösen
Beim Versuch, eine rekursive Lambda-Funktion zu definieren, schlägt die Kompilierung des folgenden Codes fehl:
auto sum = [term,next,&sum](int a, int b)mutable ->int { if(a>b) return 0; else return term(a) + sum(next(a),b); };
Der Fehler rührt von der Unfähigkeit her, „auto“ beim Initialisieren einer Lambda-Funktion zu verwenden das fängt sich ein. Die automatische Typinferenz kann den Rückgabetyp des Lambda nicht bestimmen, da er von seinen erfassten Variablen abhängt.
Um dieses Problem zu beheben, können die folgenden Schritte unternommen werden:
Verwenden Sie einen vollständig spezifizierten Funktionsobjekttyp:
std::function<int(int,int)> sum = [term,next,&sum](int a, int b)->int { if(a>b) return 0; else return term(a) + sum(next(a),b); };
Durch die Angabe des Funktionsobjekttyps entfällt die Notwendigkeit Automatische Typinferenz, die es dem Compiler ermöglicht, den Rückgabetyp genau zu bestimmen.
Funktionsobjekt später initialisieren:
std::function<int(int, int)> sum; sum = [term, next, &sum](int a, int b) -> int { if (a > b) return 0; else return term(a) + sum(next(a), b); };
Funktion initialisieren Ein Objekt ohne Anfangswert ermöglicht es dem Compiler, seinen Typ in der Zuweisungsanweisung abzuleiten.
Das obige ist der detaillierte Inhalt vonWarum kann meine rekursive Lambda-Funktion nicht kompiliert werden und wie kann ich das Problem beheben?. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!