尝试运行带有浮点参数的重载函数时出错。
我试图用c++创建一个简单的(绝对)函数,我已经创建了两个同名函数,一个接受整数并返回整数,另一个接受浮点数并返回浮点数,但每次尝试运行代码时都收到此错误:
"错误:调用重载的‘Absolute(Double)’不明确"
我尝试更改第二个函数的输入参数,以便它接受双精度值并返回浮点型,并且代码运行良好。我想知道当参数和返回类型都设置为浮点型时代码无法运行的原因,谢谢。
#include <iostream>
#include <fstream>
using namespace std;
int absolute(int x){
if (x<0){
x=-x;
}
return x;
}
float absolute (float x)
{
if (x<0){
x=-x;
}
return x;
}
int main( )
{
cout << absolute(3.5);
}
解决方案
文字3.5
的类型是double
,而不是float
。
您可以使用3.5f
使其成为float
文本。
cout << absolute(3.5f);
更好的解决方案(IMO)是使用函数模板。
template <typename T>
T absolute(T x)
{
return (x < 0 ? -x : x);
}
相关文章