为什么成员函数调用是"ambiguous"?
Why is member function call "ambiguous"?
为什么我的重载成员函数只是 "ambiguous" 作为 char 而不是 int 和 string?
我正在尝试通过重载的 equals() 函数汇集代码,为我的 Char class 创建单代码路径。当我将 equals 用作 int 和 string 但作为 char 不明确时,它工作正常。
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 上,这令人困惑,因为 string 可以正常工作。我希望它对所有人都有效,因为到目前为止都是如此。
您可以使用单个 equal
方法来接受 char
或 int
。喜欢
void euqals(unsigned int c_i);
这是模棱两可的,因为如果你这样做
Char c(42);
编译器不知道它是否应该调用 char
或 int
构造函数。两者都非常匹配。
equals(123);
也是如此。同样,char
和 int
重载都匹配,编译器无法判断您打算调用哪一个。
为什么我的重载成员函数只是 "ambiguous" 作为 char 而不是 int 和 string?
我正在尝试通过重载的 equals() 函数汇集代码,为我的 Char class 创建单代码路径。当我将 equals 用作 int 和 string 但作为 char 不明确时,它工作正常。
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 上,这令人困惑,因为 string 可以正常工作。我希望它对所有人都有效,因为到目前为止都是如此。
您可以使用单个 equal
方法来接受 char
或 int
。喜欢
void euqals(unsigned int c_i);
这是模棱两可的,因为如果你这样做
Char c(42);
编译器不知道它是否应该调用 char
或 int
构造函数。两者都非常匹配。
equals(123);
也是如此。同样,char
和 int
重载都匹配,编译器无法判断您打算调用哪一个。