对两种不同类型的数值变量使用`std::max()`函数时,c++编译器为什么出错
本文介绍了对两种不同类型的数值变量使用`std::max()`函数时,c++编译器为什么出错的处理方法,对大家解决问题具有一定的参考价值,需要的朋友们下面随着小编来一起学习吧!
问题描述
在std::max()
函数中使用两个不同的数值变量类型时,c++编译器给出错误有什么原因吗?(例如int
和long
)。
我的意思类似于:"有时对两种不同的数值变量类型使用std::max()
函数时会出现此问题,因此编译器会给出错误以防止此问题"。
推荐答案
编译器产生错误,因为它无法对std::max
的模板参数执行类型推导。以下是std::max
模板的声明方式:两个参数使用相同的类型(模板参数)。如果参数的类型不同,则演绎变得不明确。
如果通过显式提供模板参数来解决演绎歧义,则可以将不同类型用作std::max
参数
std::max(1, 2.0); // Error
std::max<double>(1, 2.0); // OK
std::max
坚持其参数使用公共类型(而不是使用两个独立类型)的原因在@bolov的回答中描述:该函数实际上希望将引用返回到最大值。
这篇关于对两种不同类型的数值变量使用`std::max()`函数时,c++编译器为什么出错的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持编程学习网!