c++ - 重载 C++ 函数浮点参数错误

标签 c++ compiler-errors floating-point overloading

这个问题在这里已经有了答案:





Strange ambiguous call to overloaded function error

(11 个回答)


7 个月前关闭。




我一直在编写一对重载的 C++ 函数,一个采用 2 个整数参数,另一个采用 2 个浮点数。

但是代码块编译器说:

error: call of overloaded 'func(double, double)' is ambiguous

为什么double如果我指定 float ?

我正在使用这两个函数来求和它们的值并在 cout 上显示结果在他们里面。作为参数给出的浮点值是 1.14 和 3.33,不是大的浮点数......

有人知道吗?谢谢!
#include <iostream>
using namespace std;

void func(int a, int b) {
    cout << a+b;
}

void func(float a, float b) 
    cout << a+b;
}

int main() {
  func(3, 7);
  func(1.14, 3.33);

}

最佳答案

函数调用func(1.14, 3.33)是模棱两可的,因为 1.143.33是 double ,两者都可以转换为 intfloat .因此编译器不知道调用哪个函数。
您可以通过显式指定常量的类型来解决此问题 func(float(1.14), float(3.33))或通过从 func(float, float) 更改重载至func(double, double) .
在这种情况下,明确告诉编译器使用哪种类型可能是一个更好的主意。

关于c++ - 重载 C++ 函数浮点参数错误,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/49836364/

相关文章:

c++ - 我如何并行化这个暴力攻击算法

c++ - GDB 断点在 asio socket->connect 调用后停止工作

c++ - 可以在 g++ 4.7+ 中重新启用 `uint` 类型吗?

asp.net-mvc-3 - Razor View 中的CS1003错误

在 Ubuntu 11.10 下从源代码编译ettercap 0.7.4.1(链接器错误)

C++ lambda指针/引用内存占用之争

c++ - C++中 "Expected a statement"是什么意思

java - 在 Java 中将字符串转换为带 2 个小数位的十进制数

haskell - 将两个 Int 值相除以获得 Float 的正确方法是什么?

c++ - 为什么使用 2 位小数精度格式化的 0.125 显示 "0.12"而不是 "0.13"?