我试图将一些模板化函数包装成一些二进制函数,如下所示。当我尝试编译代码时,我有错误
error: no match for call to ‘(QtyAsc) (myobj&, myobj&)
我认为在operator()
中QtyAsc
是一个类中的函数,模板推导机制会起作用,但似乎编译器不接受myobj
类作为有效的类型。
可能是因为对boost::bind
的电话?我试图为第二个模板化参数提供默认实现(遗憾的是我不能使用带有默认模板化参数的C ++ 11)。
class myobj {
public:
myobj(int val) : qty_(val) {}
int qty() { return qty_;}
private:
int qty_;
};
template<class T>
int get_quantity(const T& o) {
throw runtime_error("get_quantity<T> not implemented");
}
template<>
int get_quantity(const myobj& o) {
return o.qty();
}
struct QtyAsc {
template<class T, class QEx >
bool operator()(const T& o1, const T& o2, QEx extr = boost::bind(&get_quantity<T>,_1)) const {
if(extr(o1) < extr(o2))
return true;
return false;
}
};
int main() {
myobj t1(10),t2(20);
QtyAsc asc;
if(asc(t1,t2))
cout << "Yes" << endl;
}
答案 0 :(得分:3)
如果您不能使用C ++ 11,只需提供额外的重载:
struct QtyAsc {
template<class T, class QEx >
bool operator()(const T& o1, const T& o2, QEx extr) const {
return extr(o1) < extr(o2);
}
template<class T>
bool operator()(const T& o1, const T& o2) const {
return operator()(o1, o2, &get_quantity<T>);
}
};
(我省略了不必要的boost::bind
。)此外,您需要将myobj::qty
声明为const
:
int qty() const {
return qty_;
}
因为你想在const
个对象上调用它。 (Live demo)