尝试运行带有浮点参数的重载函数时出错。

2022-03-10 00:00:00 function overloading c++ c++11

我试图用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);
}

相关文章