为什么成员函数调用"ambiguous"?
Why is member function call "ambiguous"?
为什么我的重载成员函数只"模棱两可"地作为字符而不是整数和字符串?
我正在尝试通过重载的 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);
也是如此.同样,char
和 int
重载都匹配,编译器无法判断您打算调用哪一个。
您可以使用单个equal
方法来接受char
或int
。
void euqals(unsigned int c_i);
相关文章:
- 函数调用中参数的顺序重要吗
- 基于另一个成员参数将函数调用从类传递给它的一个成员
- 变量没有改变?通过向量的函数调用
- 在两个类中共享相同的函数调用,并在不需要时避免空实例化
- 是否有C++编译器选项允许激进地删除所有函数调用,并将参数传递给具有空体的函数
- 我知道函数调用中存在歧义.有没有办法调用foo()函数
- 模板函数调用
- 获取从C++中同一类中的构造函数调用的方法返回的值
- 析构函数调用
- 成员函数调用和C++对象模型
- 使用共享指针的函数调用,其对象应为 const
- C++:编译时检查匹配的函数调用对?
- 函数调用C++中的参数太少
- 来自 DLL 的函数调用 [表观调用的括号前面的表达式必须具有(指向-)函数类型]
- 返回指向对象的指针的函数调用是否为 prvalue?
- C++ 如何重载 [] 运算符并进行函数调用
- 代码的效率. 转到和函数调用
- 是同一作用域的函数部分中的函数调用
- 为什么将"<<"运算符作为函数调用会导致"ambiguous call"编译器错误?
- 为什么成员函数调用"ambiguous"?