data:image/s3,"s3://crabby-images/7e462/7e462d7dd00158b0a067f8a3b23a8e5edd2e9dce" alt=""
Alexander Shyrokov wrote:
In such a situation I tend to define my own nullptr:
struct nullptr_t { template<class T> operator T* () const { return 0; } } nullptr;
and use that instead of NULL. Thanks, Peter. Both casting and nullptr worked fine. But it brings me to a bigger question, should I bother replacing this code:
struct c{void f(char*){}}; typedef std::map
TMap; TMap a; for(TMap::iterator i=a.begin();i!=a.end();++i)(*a)->second.f(NULL): with the more complex code like this:
struct c{void f(char*){}}; struct nullptr_t{template<class T>operator T*()const{return 0;}}nullptr; typedef std::map
TMap; TMap a; std::for_each(a.begin(),a.end(), boost::bind(&c::f, boost::bind(&TMap::value_type::second,_1), nullptr) ); I know there should be a line. But I am new to the algorithm's way :)
Good question. I tend to prefer for_each_pair( a.begin(), a.end(), boost::bind( &c::f, _2, nullptr ) ); over the explicit loop, and two nested binds aren't automatically out of the question, but for anything more than that the low-tech approach wins. But this is subjective, and it also depends on who'll be reading the code. I don't include for_each_pair and nullptr as part of the complexity since they are one-time investments that can be reused.