对两种不同类型的数值变量使用`std::max()`函数时,c++编译器为什么出错

Why c++ compiler gives error when using `std::max()` function for two different type of numeric variable(对两种不同类型的数值变量使用`std::max()`函数时,c++编译器为什么出错)

本文介绍了对两种不同类型的数值变量使用`std::max()`函数时,c++编译器为什么出错的处理方法,对大家解决问题具有一定的参考价值,需要的朋友们下面随着小编来一起学习吧!

问题描述

std::max()函数中使用两个不同的数值变量类型时,c++编译器给出错误有什么原因吗?(例如intlong)。

我的意思类似于:"有时对两种不同的数值变量类型使用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++编译器为什么出错的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持编程学习网!

本文标题为:对两种不同类型的数值变量使用`std::max()`函数时,c++编译器为什么出错