Home > Backend Development > C++ > Why Do Compilers Optimize Lambdas Better Than Plain Functions?

Why Do Compilers Optimize Lambdas Better Than Plain Functions?

Mary-Kate Olsen
Release: 2024-12-02 02:20:09
Original
183 people have browsed it

Why Do Compilers Optimize Lambdas Better Than Plain Functions?

Lambda Function Optimization

Nicolai Josuttis claims in "The C Standard Library" that compilers optimize lambdas better than plain functions. This raises the question of why this is the case.

Inline Optimization

One might assume that inline optimization wouldn't differentiate between lambdas and plain functions. However, the key difference lies in the nature of lambdas as function objects.

Function Objects vs. Function Pointers

When a lambda is passed to a function template, it creates a new function specifically for that object, resulting in a trivially inlinable function call. In contrast, plain functions pass function pointers, which typically cause problems for inline optimization. Compilers can theoretically inline such calls, but only if the surrounding function is also inlined.

Example

Consider a function template map that takes an iterator and a function object as parameters:

template <typename Iter, typename F>
void map(Iter begin, Iter end, F f) {
    for (; begin != end; ++begin)
        *begin = f(*begin);
}
Copy after login

Invoking this template with a lambda:

int a[] = { 1, 2, 3, 4 };
map(begin(a), end(a), [](int n) { return n * 2; });
Copy after login

Creates a new instantiation of the function:

template <>
void map<int*, _some_lambda_type>(int* begin, int* end, _some_lambda_type f) {
    for (; begin != end; ++begin)
        *begin = f.operator()(*begin);
}
Copy after login

The compiler can readily inline calls to the lambda's operator().

However, when using a function pointer:

int a[] = { 1, 2, 3, 4 };
map(begin(a), end(a), &my_function);
Copy after login

The resulting instantiation becomes:

template <>
void map<int*, int (*)(int)>(int* begin, int* end, int (*f)(int)) {
    for (; begin != end; ++begin)
        *begin = f(*begin);
}
Copy after login

Here, f points to a different address for each call to map, prohibiting inline optimization unless the surrounding call to map is also inlined.

Thus, the optimization advantage of lambdas stems from their ability to create function objects that enable trivial inline capabilities.

The above is the detailed content of Why Do Compilers Optimize Lambdas Better Than Plain Functions?. For more information, please follow other related articles on the PHP Chinese website!

source:php.cn
Statement of this Website
The content of this article is voluntarily contributed by netizens, and the copyright belongs to the original author. This site does not assume corresponding legal responsibility. If you find any content suspected of plagiarism or infringement, please contact admin@php.cn
Latest Articles by Author
Popular Tutorials
More>
Latest Downloads
More>
Web Effects
Website Source Code
Website Materials
Front End Template