Pab*_*yes 3 c++ operator-overloading
我有这个:
typedef string domanin_name;
Run Code Online (Sandbox Code Playgroud)
然后,我尝试以这种方式重载运算符<
bool operator<(const domain_name & left, const domain_name & right){
int pos_label_left = left.find_last_of('.');
int pos_label_right = right.find_last_of('.');
string label_left = left.substr(pos_label_left);
string label_right = right.substr(pos_label_right);
int last_pos_label_left=0, last_pos_label_right=0;
while(pos_label_left!=string::npos && pos_label_right!=string::npos){
if(label_left<label_right) return true;
else if(label_left>label_right) return false;
else{
last_pos_label_left = pos_label_left;
last_pos_label_right = pos_label_right;
pos_label_left = left.find_last_of('.', last_pos_label_left);
pos_label_right = right.find_last_of('.', last_pos_label_left);
label_left = left.substr(pos_label_left, last_pos_label_left);
label_right = right.substr(pos_label_right, last_pos_label_right);
}
}
}
Run Code Online (Sandbox Code Playgroud)
我知道这是一种使运算符重载的奇怪方法<,但我必须这样做.它应该做我想要的.这不是重点.
问题是它在这一行中进入无限循环:
if(label_left<label_right) return true;
Run Code Online (Sandbox Code Playgroud)
似乎它试图使用这个重载函数本身进行比较,但label_left是一个字符串,而不是域名!
有什么建议吗?
Jes*_*der 12
typedef只给出一个类型的另一个名称.它并没有创造一个独特的类型.因此,实际上,你超载operator <了string.
如果您想创建一个不同的类型,那么您可以尝试
struct domain_name {
string data;
// ...
};
Run Code Online (Sandbox Code Playgroud)
并与之合作.