Lambda question (deferring evaluation)
Hi,
would it be possible to implement something the following lines using
lambda, without having all values referring to the same shared object:
...
#include
Johan Nilsson wrote: [...]
std::vector
foos(10); std::for_each(foos.begin(), foos.end(), _1 = shared_ptr<Foo>(new Foo));
Lambda way (according to the docs, I haven't tried it): std::for_each( foos.begin(), foos.end(), _1 = bind( constructor< shared_ptr<Foo> >(), new_ptr<Foo>() ) ); (probably leaks when new throws) Old school way: shared_ptr<Foo> createFoo() { return shared_ptr<Foo>( new Foo ); } std::generate( foos.begin(), foos.end(), createFoo );
"Peter Dimov"
Johan Nilsson wrote:
[...]
std::vector
foos(10); std::for_each(foos.begin(), foos.end(), _1 = shared_ptr<Foo>(new Foo)); Lambda way (according to the docs, I haven't tried it):
std::for_each( foos.begin(), foos.end(), _1 = bind( constructor< shared_ptr<Foo> >(), new_ptr<Foo>() ) );
I searched the docs but obviously missed/skipped that part ... embarrassing.
(probably leaks when new throws)
Old school way:
shared_ptr<Foo> createFoo() { return shared_ptr<Foo>( new Foo ); }
std::generate( foos.begin(), foos.end(), createFoo );
Cleaner, nicer (but one of my intentions was to finally get around to learn how to use BLL). Thanks // Johan
"Peter Dimov"
Johan Nilsson wrote:
[...]
std::vector
foos(10); std::for_each(foos.begin(), foos.end(), _1 = shared_ptr<Foo>(new Foo)); Lambda way (according to the docs, I haven't tried it):
std::for_each( foos.begin(), foos.end(), _1 = bind( constructor< shared_ptr<Foo> >(), new_ptr<Foo>() ) );
(probably leaks when new throws)
Old school way:
shared_ptr<Foo> createFoo() { return shared_ptr<Foo>( new Foo ); }
std::generate( foos.begin(), foos.end(), createFoo );
here is also BOOST_FOREACH way: BOOST_FOREACH( shared_ptr<Foo>&, elem, foos ) elem.reset( new Foo ); Gennadiy
Taking into account "Lambda expressions in details"->"Construction and destruction" docs,
perhaps this way:
std::for_each(foos.begin(), foos.end(),
_1 = bind(constructor
participants (4)
-
Gennadiy Rozental
-
Johan Nilsson
-
Peter Dimov
-
Roman