正如标题所述,为什么下面的代码要将一些元素与它们自身进行比较?
#include <iostream>
#include <vector>
#include <algorithm>
class a {
public:
a(int value): value(value) {}
~a() {}
bool operator<(const a& rhs) const {
if(this->value == rhs.value)
std::cout << this << " " << this->value << "\t"
<< &rhs << " " << rhs.value << std::endl;
if(this->value < rhs.value)
return true;
return false;
}
int value;
};
int main(int argc, char* argv[]) {
std::vector<a> vec;
for(int i = 0; i < 17; i++)
vec.push_back(a(i));
std::sort(vec.begin(), vec.end());
return 0;
}
我在Windows、Linux和OpenBSD上尝试了以上代码,似乎在Windows上它不会将元素与自身进行比较,但在Linux和OpenBSD上都会。我的猜测是因为使用了不同的库。
在Linux上,我得到类似以下的输出:
0x96be0d0 8 0xbfc2945c 8
0xbfc2945c 8 0x96be0d0 8
==
运算符,那么sort
如何判断不同地址上的元素是否相同呢? - Barmara < b
相对于&a == &b ? false : a < b
来说是更短的代码。然而每次比较都需要进行额外的&a == &b
测试,只是为了避免在少数自比较中使用a < b
测试。一般情况下,这不是一个好的权衡。 - Oktalist