У меня есть класс CMyVector
, который содержит вектор указателей на объекты CMyClass
, и у меня есть несколько функций поиска для найти элементы по разным критериям. Так, например, у меня есть:
CMyClass* CMyVector::FindByX(int X);
CMyClass* CMyVector::FindByString(const CString& str);
CMyClass* CMyVector::FindBySomeOtherClass(CSomeOtherClass* ptr);
// Other find functions...
Сначала они были реализованы как циклы, проходящие по вектору в поисках элемента, который соответствует X, str, ptr или чему-то еще. Итак, я создал предикаты, вроде этого:
class IsSameX:public unary_function<CMyClass*, bool>
{
int num;
public:
IsSameX(int n):num(n){}
bool operator()(CMyClass* obj) const
{
return (obj != NULL && (obj->X() == num));
}
};
И закончил набором функций, которые все выглядят так:
CMyClass* CMyVector::FindByX( int x )
{
CMyVector::iterator it = find_if(vec.begin(), vec.end(), IsSameX(x));
if (it != vec.end())
{
return *it;
}
return NULL;
}
Все они выглядят одинаково, за исключением вызываемого предиката, поэтому я подумал о упростив еще больше, и создал такую функцию:
CMyClass* CMyVector::Find( ThisIsWhatIDontKnow Predicate)
{
CMyVector::iterator it = find_if(vec.begin(), vec.end(), Predicate);
if (it != vec.end())
{
return *it;
}
return NULL;
}
And do:
CMyClass* CMyVector::FindByX( int x )
{
return Find(IsSameX(x));
}
И так далее.
Итак, мой вопрос: как мне объявить мою функцию Find
, чтобы я мог передать ей свои предикаты? Я пробовал несколько способов, но пока безуспешно.