Heim > Backend-Entwicklung > C++ > Warum optimieren Compiler Lambdas besser als einfache Funktionen?

Warum optimieren Compiler Lambdas besser als einfache Funktionen?

Mary-Kate Olsen
Freigeben: 2024-12-02 02:20:09
Original
183 Leute haben es durchsucht

Why Do Compilers Optimize Lambdas Better Than Plain Functions?

Lambda-Funktionsoptimierung

Nicolai Josuttis behauptet in „The C Standard Library“, dass Compiler Lambdas besser optimieren als einfache Funktionen. Dies wirft die Frage auf, warum das so ist.

Inline-Optimierung

Man könnte annehmen, dass die Inline-Optimierung nicht zwischen Lambdas und einfachen Funktionen unterscheiden würde. Der Hauptunterschied liegt jedoch in der Natur von Lambdas als Funktionsobjekte.

Funktionsobjekte vs. Funktionszeiger

Wenn ein Lambda an eine Funktionsvorlage übergeben wird, wird es erstellt eine neue Funktion speziell für dieses Objekt, was zu einem trivial inlinierbaren Funktionsaufruf führt. Im Gegensatz dazu übergeben einfache Funktionen Funktionszeiger, die typischerweise Probleme bei der Inline-Optimierung verursachen. Compiler können solche Aufrufe theoretisch inline, aber nur, wenn die umgebende Funktion ebenfalls inline ist.

Beispiel

Stellen Sie sich eine Funktionsvorlagenzuordnung vor, die einen Iterator und ein Funktionsobjekt als akzeptiert Parameter:

template <typename Iter, typename F>
void map(Iter begin, Iter end, F f) {
    for (; begin != end; ++begin)
        *begin = f(*begin);
}
Nach dem Login kopieren

Aufrufen dieser Vorlage mit a lambda:

int a[] = { 1, 2, 3, 4 };
map(begin(a), end(a), [](int n) { return n * 2; });
Nach dem Login kopieren

Erstellt eine neue Instanziierung der Funktion:

template <>
void map<int*, _some_lambda_type>(int* begin, int* end, _some_lambda_type f) {
    for (; begin != end; ++begin)
        *begin = f.operator()(*begin);
}
Nach dem Login kopieren

Der Compiler kann den Operator() des Lambda problemlos inline aufrufen.

Jedoch wann unter Verwendung eines Funktionszeigers:

int a[] = { 1, 2, 3, 4 };
map(begin(a), end(a), &my_function);
Nach dem Login kopieren

Die resultierende Instanziierung wird zu:

template <>
void map<int*, int (*)(int)>(int* begin, int* end, int (*f)(int)) {
    for (; begin != end; ++begin)
        *begin = f(*begin);
}
Nach dem Login kopieren

Hier zeigt f auf eine andere Adresse für jeden Map-Aufruf, was eine Inline-Optimierung verhindert, es sei denn, der umgebende Map-Aufruf ist ebenfalls inline.

Daher ist der Optimierungsvorteil von Lambdas beruhen auf ihrer Fähigkeit, Funktionsobjekte zu erstellen, die triviale Inline-Funktionen ermöglichen.

Das obige ist der detaillierte Inhalt vonWarum optimieren Compiler Lambdas besser als einfache Funktionen?. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Quelle:php.cn
Erklärung dieser Website
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn
Neueste Artikel des Autors
Beliebte Tutorials
Mehr>
Neueste Downloads
Mehr>
Web-Effekte
Quellcode der Website
Website-Materialien
Frontend-Vorlage