data:image/s3,"s3://crabby-images/3576f/3576fc9f71764b906dea75f1522a898399f9ab7d" alt=""
An iterator is pointing to a pointer, how do I add another dereferencing
operator in the algorithm, so it works on values?
void f(int& i);
vector
data:image/s3,"s3://crabby-images/b4e66/b4e6618abd88571690777d58d3e735c7f53bb18c" alt=""
Alexander Shyrokov
An iterator is pointing to a pointer, how do I add another dereferencing operator in the algorithm, so it works on values?
You might try http://www.boost.org/libs/iterator/indirect_iterator.html
void f(int& i); vector
a; // this would work if f would be void f(int* i) for_each(a.begin(),a.end(),boost::bind(f,_1)); I could define a dereferencing predicate: template<class T> struct deref{ typedef T result_type; T operator()(T* p){assert(p);return *p;} }; for_each(a.begin(),a.end(),boost::bind(f,boost::bind(deref<int>,_1)));
std::for_each( boost::make_indirect_iterator(a.begin()) , boost::make_indirect_iterator(a.end()) , some_operation ); -- Dave Abrahams Boost Consulting www.boost-consulting.com
data:image/s3,"s3://crabby-images/7e462/7e462d7dd00158b0a067f8a3b23a8e5edd2e9dce" alt=""
Alexander Shyrokov wrote:
An iterator is pointing to a pointer, how do I add another dereferencing operator in the algorithm, so it works on values?
void f(int& i); vector
a; // this would work if f would be void f(int* i) for_each(a.begin(),a.end(),boost::bind(f,_1)); I could define a dereferencing predicate: template<class T> struct deref{ typedef T result_type; T operator()(T* p){assert(p);return *p;} }; for_each(a.begin(),a.end(),boost::bind(f,boost::bind(deref<int>,_1)));
but this requires supplying a template parameter. Is there an easier way?
Not with boost::bind, but Lambda allows you to write bind( f, *_1 ). You need to use Lambda's bind and _1 though. :-)
participants (3)
-
Alexander Shyrokov
-
David Abrahams
-
Peter Dimov