C++ c+中的函数重载+;不起作用
当我运行这个程序时,它会产生错误C++ c+中的函数重载+;不起作用,c++,C++,当我运行这个程序时,它会产生错误[error]重载的“add(double,double,double)”调用是不明确的 为什么呢?我的意思是函数参数有不同的数据类型,这实际上是函数重载,那么为什么会出错呢 但是,当浮动被double替换时,它工作正常 #include<iostream> using namespace std; void add(){ cout<<"I am parameterless and return nothing";
[error]重载的“add(double,double,double)”调用是不明确的
为什么呢?我的意思是函数参数有不同的数据类型,这实际上是函数重载,那么为什么会出错呢
但是,当浮动被double替换时,它工作正常
#include<iostream>
using namespace std;
void add(){
cout<<"I am parameterless and return nothing";
}
int add( int a, int b ){
int z = a+b;
return z;
}
int add(int a, int b, int c){
int z = a+b+c;
return z;
}
int add(float a, float b, float c)
{
int z = a +b + c;
return z;
}
int main()
{
cout<<"The void add() function -> ";
add();
cout<<endl;
cout<<"add(2,3) -> "<<add(2,3)<<endl;
cout<<"add(2,3,4) -> "<<add(2,3,4)<<endl;
cout<<"add(2.1,4.5) -> "<<add(2.8,3.1,4.1)<<endl;
return 0;
}
#包括
使用名称空间std;
void add(){
cout因为您使用doubleliteral调用函数,这些可以转换为int
或float
,编译器不知道应该选择哪个
最简单的解决方案是使用float
literals调用函数:
add(2.8f,3.1f,4.1f)
因为您使用double
literal调用函数,这些可以转换为int
或float
,编译器不知道应该选择哪个
最简单的解决方案是使用float
literals调用函数:
add(2.8f,3.1f,4.1f)