尝试运行带有浮点参数的重载函数时出错。 [英] error when trying to run an overloaded function with float parameters.

查看:83
本文介绍了尝试运行带有浮点参数的重载函数时出错。的处理方法,对大家解决问题具有一定的参考价值,需要的朋友们下面随着小编来一起学习吧!

问题描述

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

这篇关于尝试运行带有浮点参数的重载函数时出错。的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持IT屋!

查看全文
登录 关闭
扫码关注1秒登录
发送“验证码”获取 | 15天全站免登陆