递归问题重载运算符

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)

并与之合作.