为什么成员函数调用"ambiguous"?

Why is member function call "ambiguous"?

本文关键字:ambiguous 函数调用 成员 为什么      更新时间:2023-10-16

为什么我的重载成员函数只"模棱两可"地作为字符而不是整数和字符串?

我正在尝试通过重载的 equals(( 函数汇集代码,为我的 Char 类创建一个单代码路径。当我使用 equals 作为 int 和字符串但作为字符时,它工作正常。

class Char
{
private:
    char cData;
    int iData;
    string sData;
public:
    //Mutators:
    void equals(char c);
    void equals(int c);
    void equals(string c);
    //Constructors:
    Char(char c);
    Char(int c);
    Char(string c);
};
void Char::equals(char c)
{
    cData = c;
}
void Char::equals(int c)
{
    iData = c;
}
void Char::equals(string c)
{
    sData = c;
}
Char::Char(char c)
{
    this->equals(c); //Call to member function 'equals' is ambiguous
}
Char::Char(int c)
{
    this->equals(c);
}
Char::Char(string c)
{
    this->equals(c);
}

该错误仅发生在char上,这令人困惑,因为字符串工作正常。我希望它对所有人都有效,因为到目前为止情况就是这样。

这是模棱两可的,因为如果你这样做

Char c(42);

编译器不知道它应该调用char还是int构造函数。两者同样匹配。

equals(123);也是如此.同样,charint 重载都匹配,编译器无法判断您打算调用哪一个。

您可以使用单个equal方法来接受charint

void euqals(unsigned int c_i);