我在代码中发现了一个错误,我在排序结构容器时忘记使用自定义比较器。这让我想知道它是什么用作小于运算符,因为我没有为结构定义任何。
如果未定义这些运算符,对象如何比较&lt ;,>和==?是内存地址吗?它是在标准中定义的吗?我在Google上找不到任何此类信息。
编辑:
这是我正在使用的课程:
using namespace std;
typedef unsigned id;
class LogEntry {
id master_id;
string timestamp;
string category;
string message;
string str_rep;
public:
LogEntry(id id, string t, string c, string m) :
master_id(id), timestamp(t), category(c), message(m) {
}
string get_timestamp() const {
return timestamp;
}
string get_category() const {
return category;
}
string get_message() const {
return message;
}
string to_string() {
ostringstream ss;
ss << master_id << "|" << timestamp << "|" << category << "|"
<< message;
return ss.str();
}
id get_id() const {
return master_id;
}
};
EDIT2:
我意识到我犯了一个愚蠢的错误。我正在存储指向对象的指针向量。因此,指针很可能通过地址进行比较。如果我没有存储指针,我认为它不会编译。
EDIT3: KerrekSB在他的回答评论中发布了一个相关的有趣链接:How can pointers be totally ordered?
答案 0 :(得分:9)
默认比较器是标准模板std::less<T>
,它只使用x < y
用于x
类型的y
和T
。有很多方法可以解决这个问题:
T
是算术基本类型,使用内置运算符。
T
是一种班级类型,其成员为operator<
。
有一个免费功能operator<(T const &, T const &)
。
您的用户定义类型具有内置类型的隐式转换功能,该类型为调用内置<
提供了唯一的路径。
此外,您可以为用户定义的类型std::less
专门设置T
。