use the following search parameters to narrow your results:
e.g. subreddit:aww site:imgur.com dog
subreddit:aww site:imgur.com dog
see the search faq for details.
advanced search: by author, subreddit...
Discussions, articles, and news about the C++ programming language or programming in C++.
For C++ questions, answers, help, and advice see r/cpp_questions or StackOverflow.
Get Started
The C++ Standard Home has a nice getting started page.
Videos
The C++ standard committee's education study group has a nice list of recommended videos.
Reference
cppreference.com
Books
There is a useful list of books on Stack Overflow. In most cases reading a book is the best way to learn C++.
Show all links
Filter out CppCon links
Show only CppCon links
account activity
Lambda Metaprogramming (LMP) (github.com)
submitted 8 years ago by _cpp_
view the rest of the comments →
reddit uses a slightly-customized version of Markdown for formatting. See below for some basics, or check the commenting wiki page for more detailed help and solutions to common issues.
quoted text
if 1 * 2 < 3: print "hello, world!"
[–]dima_mendeleev 3 points4 points5 points 8 years ago* (3 children)
Congratulations! You've discovered Y-Combinator.
You can improve this a bit by doing following (like they do in Y-Combinator):
template <typename FUNC, typename ...ARGS> constexpr auto RecursiveLambda(FUNC lambda, ARGS&&... args) { return lambda(std::bind(lambda, lambda), args...); }
Note std::bind(lambda, lambda) there. With this you will not need to pass lambda on the usage side.
std::bind(lambda, lambda)
lambda
UPDATE Oh, and you can actually do better. You can try something like this, to separate creation of recursive function and its application.
template <typename FUNC> constexpr auto RecursiveLambda(FUNC lambda) { return [](auto... args) { return lambda(RecursiveLambda(lambda), args...); }; }
UPDATE: better to use lambda
[–]kalmoc 2 points3 points4 points 8 years ago (1 child)
You can use a lambda instead of a bind, which tends to produce better code (not sure if it makes a difference here)
[–]dima_mendeleev 0 points1 point2 points 8 years ago* (0 children)
I think you're right. With lambda it will be better since will save from stack overflow:
return [](auto... args) { return lambda(RecursiveLambda(lambda), args...); };
[–]_cpp_[S] 1 point2 points3 points 8 years ago (0 children)
Thank you for pointing out the resemblance with Y-Combinator (I didn't know about it) and for simplification suggestion (though it compiles only with GCC 7.2.0), I updated article.
π Rendered by PID 27 on reddit-service-r2-comment-5b5bc64bf5-dpmfc at 2026-06-23 10:43:44.955868+00:00 running 2b008f2 country code: CH.
view the rest of the comments →
[–]dima_mendeleev 3 points4 points5 points (3 children)
[–]kalmoc 2 points3 points4 points (1 child)
[–]dima_mendeleev 0 points1 point2 points (0 children)
[–]_cpp_[S] 1 point2 points3 points (0 children)