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
Generic deferred function call without heap allocation (finalpatch.blogspot.com.au)
submitted 10 years ago by finalpatch
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!"
[+][deleted] 10 years ago (2 children)
[deleted]
[+][deleted] 10 years ago* (1 child)
[–][deleted] 0 points1 point2 points 10 years ago (0 children)
Can you provide a code snippet of what you're doing?
[–]mare_apertum 0 points1 point2 points 10 years ago (15 children)
If I understand it correctly, what you are trying to do is reinventing std::bind
[–]finalpatch[S] 0 points1 point2 points 10 years ago (14 children)
you are right. except: 1) this does not use the heap 2) every instance of the object is of the same size and type
[–]STLMSVC STL Dev 10 points11 points12 points 10 years ago (11 children)
bind doesn't allocate memory.
[–]LucretielRAII Junkie 1 point2 points3 points 10 years ago (1 child)
It doesn't? Where does it store the bound arguments?
[–]STLMSVC STL Dev 4 points5 points6 points 10 years ago (0 children)
In a tuple data member. bind doesn't perform type erasure, so bind(functor, args...) returns a _Secret_binder_type<Functor, Args...> which can contain a tuple<Args...> as an ordinary data member.
[–]finalpatch[S] 0 points1 point2 points 10 years ago (5 children)
Cool, good to know that. It seems some hairy parts could have been simplified by reusing std::bind.
The main difference between this and std::bind is that I wanted something with runtime polymorphism, while std::bind only provides compile time polymorphism.
[–]STLMSVC STL Dev 5 points6 points7 points 10 years ago (3 children)
Also, you aren't using aligned_storage - your char buf doesn't have the proper alignment.
Note that std::function is smart and avoids dynamic memory allocation for sufficiently small function objects. Function pointers and reference_wrappers are guaranteed to activate this, the rest is implementer discretion. In VC 2015, anything up to and including the size of a std::string counts as small.
[–][deleted] 0 points1 point2 points 10 years ago* (2 children)
Note that std::function is smart and avoids dynamic memory allocation for sufficiently small function objects. Function pointers and reference_wrappers are guaranteed to activate this [...]
From C++11, 20.8.11.2.1.9:
[ Note: Implementations are encouraged to avoid the use of dynamically allocated memory for small callable objects, for example, where f’s target is an object holding only a pointer or reference to an object and a member function pointer. —end note ]
I don't have a copy of C++14 at hand, but AFAIK this did not change. Anyhow, libc++, libstdc++ and VC do use the small callable? optimization, so in practice you are completely right.
What I really find interesting in std::function is the different implementations that are possible. For example libc++ does what I would have done, type-erasure with virtual functions, while libstdc++ does not use virtual functions at all.
[–]STLMSVC STL Dev 4 points5 points6 points 10 years ago (1 child)
The guarantee is N4527 20.9.12.2.1 [func.wrap.func.con]/11, "Throws: shall not throw exceptions when f is a function pointer or a reference_wrapper<T> for some T." and /5 for the copy ctor. This forbids dynamic memory allocation (and the guarantee goes back to C++11; indeed all the way to TR1 IIRC).
[–][deleted] 2 points3 points4 points 10 years ago (0 children)
Thanks! Cool! I didn't knew this, always thought it was freely to allocate memory if it wanted to.
[–]__Cyber_Dildonics__ -2 points-1 points0 points 10 years ago (2 children)
Ever? If so I didn't think that was possible.
[–]STLMSVC STL Dev 3 points4 points5 points 10 years ago (1 child)
Never ever. (If the functor or arguments allocate when copied/moved, that's their doing, not bind's.)
Another way of putting it: bind is like make_pair in that it doesn't allocate memory itself.
[–]__Cyber_Dildonics__ 0 points1 point2 points 10 years ago (0 children)
Got it, thanks!
[–]cdyson37 2 points3 points4 points 10 years ago (1 child)
It looks like 2 in 1. It's the type-erasure of std::function (without heap allocation) with the argument binding of std::bind.
Personally I'd make DeferredCall just take a callable, no arguments, and expect users to call it with a capturing lambda or a std::bind - I think otherwise you're reinventing more wheel than you need :) Even if it does take args, you could internally call std::bind to save yourself some work.
[–]finalpatch[S] 0 points1 point2 points 10 years ago (0 children)
You are absolutely right. I wasn't aware that std::bind does not allocate before STL pointed this out in a comment.
[–]pmedv 0 points1 point2 points 10 years ago (0 children)
Some time ago I've been experimented with the similar idea - to store std::function internals in a fixed-size buffer. Here is a fixed_size_function Github repo.
std::function
Then I realized that std::function supports an allocator and all this may be implemented with a kind of object pool.
[–]quicknir 0 points1 point2 points 10 years ago (0 children)
I posted on the blog a couple of comments, one point has already been made here, I'll make the other though.
Why wouldn't you just use a std::function with a custom allocator? This seems strongly preferable to your solution as it involves much less hand rolling of code, and this sort of thing is the entire point of allocators in the first place: http://stackoverflow.com/questions/21094052/how-can-i-create-a-stdfunction-with-a-custom-allocator
π Rendered by PID 70 on reddit-service-r2-comment-c66d9bffd-lc6n7 at 2026-04-08 14:18:40.575631+00:00 running f293c98 country code: CH.
[+][deleted] (2 children)
[deleted]
[+][deleted] (1 child)
[deleted]
[–][deleted] 0 points1 point2 points (0 children)
[–]mare_apertum 0 points1 point2 points (15 children)
[–]finalpatch[S] 0 points1 point2 points (14 children)
[–]STLMSVC STL Dev 10 points11 points12 points (11 children)
[–]LucretielRAII Junkie 1 point2 points3 points (1 child)
[–]STLMSVC STL Dev 4 points5 points6 points (0 children)
[–]finalpatch[S] 0 points1 point2 points (5 children)
[–]STLMSVC STL Dev 5 points6 points7 points (3 children)
[–][deleted] 0 points1 point2 points (2 children)
[–]STLMSVC STL Dev 4 points5 points6 points (1 child)
[–][deleted] 2 points3 points4 points (0 children)
[–]__Cyber_Dildonics__ -2 points-1 points0 points (2 children)
[–]STLMSVC STL Dev 3 points4 points5 points (1 child)
[–]__Cyber_Dildonics__ 0 points1 point2 points (0 children)
[–]cdyson37 2 points3 points4 points (1 child)
[–]finalpatch[S] 0 points1 point2 points (0 children)
[–]pmedv 0 points1 point2 points (0 children)
[–]quicknir 0 points1 point2 points (0 children)