STL中关于_Predicate变量的传参注意事项

在使用类似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在这里只是做了一个替换,不仅仅可以传入一个函数名称,更可以传入一个对象名称,不过该对象名称需要重载()“运算符

你可能感兴趣的:(STL中关于_Predicate变量的传参注意事项)