在使用类似find_if函数时的最后一个参数时,原来只知道只用函数名称,现在可以配合类来使用,更具有封装的特性。
find_if函数的定义如下:
template<class InputIterator, class Predicate> InputIterator find_if( InputIterator _First, InputIterator _Last, Predicate _Pred
);
实现如下:
template<class _InIt,class _Pr> inline
_InIt _Find_if(_InIt _First, _InIt _Last, _Pr _Pred)
{ // find first satisfying _Pred
_DEBUG_RANGE(_First, _Last);
_DEBUG_POINTER(_Pred);
for (; _First != _Last; ++_First)
if (_Pred(*_First))
break;
return (_First);
}
注意用红色标明的一行,
传统的写法如下:
bool greater10 ( int value ) { return value >10; }
list <int> L; list <int>::iterator Iter; list <int>::iterator result; L.push_back( 5 ); L.push_back( 10 ); L.push_back( 15 ); L.push_back( 20 ); L.push_back( 10 ); cout << "L = ( " ; for ( Iter = L.begin( ) ; Iter != L.end( ) ; Iter++ ) cout << *Iter << " "; cout << ")" << endl; result = find_if( L.begin( ), L.end( ), &greater10 );
如果这样写更具有封装的特性:
class EqualValue { private: int m_nCompareVal; public: EqualValue(int nVal):m_nCompareVal(nVal) { } bool operator()(int nVal) { return m_nCompareVal == nVal; } };
vector<int> vecInts; for(int i=0;i< 5;i++) vecInts.push_back(i); EqualValue e(2); find_if(vecInts.begin(),vecInts.end(),e);注意红色文字的调用方式,相当于直接把e当做一个函数指针传进去。
总结:
_Pre在这里只是做了一个替换,不仅仅可以传入一个函数名称,更可以传入一个对象名称,不过该对象名称需要重载“()“运算符