我有一个类定义了与其他类型的严格弱排序,我想在该类的容器上使用基于比较的算法(例如std :: upper_bound)。
标准定义容器的forward iterator值类型应该是可比类型的类型,因此以下内容不能编译:
template<typename T>
class Foo {
public:
bool operator<(const T& _val) { return val < _val; }
//operator T() { return val; } // uncommenting this solves the problem
private:
T val;
};
void bar() {
vector<Foo<int>> foos(10);
auto i_lb = std::lower_bound(foos.begin(), foos.end(), 17); // compiles and works, though I don't know why
auto i_eq = std::equal_range(foos.begin(), foos.end(), 17); // error! not convertible to int
}
我找不到使用接受谓词的算法版本的方法(也要求类型相同)。定义转换运算符使此示例有效,但定义一个并不总是正确的。进行这种比较的正确方法是什么?
顺便说一句,用std :: lower_bound替换std :: equal_range有效,但我无法弄明白为什么。
答案 0 :(得分:2)
equal_range必须比较两种方式的值,以确定它们是否相等
当
时,值a
b
被视为与另一个值(!(a<b) && !(b<a))
等效
lower_bound只需找到范围的一端。
您的比较仅适用于Foo < T
,而不适用于T < Foo
。