为什么下面的重载解析调用非模板函数
Why the overload resolution below calls the non-template function?
为什么在下面的表达式return max(max(x, y), z);
中调用max(x, y)
的重载解析会导致调用非模板函数char const* max(char const*, char const*)
?
据我所知,函数max<const char*>(x, y)
比前者更适合,因为x
是const char* const&
, y
是const char* const&
!
#include <iostream>
template <typename T>
T const& max (T const& x, T const& y)
{
return x < y ? y : x;
}
char const* max (char const* x, char const* y)
{
return std::strcmp(x, y) < 0 ? y : x;
}
template <typename T>
T const& max (T const& x, T const& y, T const& z)
{
return max (max(x, y), z);
}
int main ()
{
const char* sx = "String_x";
const char* sy = "String_y";
const char* sz = "String_z";
max(sx, sy, sz);
}
为什么在下面的表达式
return max(max(x, y), z);
中调用max(x, y)
的重载解析会导致调用非模板函数char const* max(char const*, char const*)
?
当调用这个函数时:
template <typename T>
T const& max (T const& x, T const& y, T const& z)
{
return max (max(x, y), z);
}
T
推导为const char*
。因此,这个签名被实例化:
const char* const& max (
const char* const& x,
const char* const& y,
const char* const& z
)
函数内部调用二进制版本的max()
,参数类型为const char*
。对于const char*
类型的实参,模板和非模板重载都是可行的。
然而,当两个函数都可以解析调用且其中一个不是模板时,非模板版本被认为是最合适的。
根据c++ 11标准第13.3.3/1段:
给定这些定义,**一个可行函数F1被定义为优于另一个可行函数的函数F2 if**对于所有参数i, ICSi(F1)不是比ICSi(F2)更差的转换序列,然后
-对于某些参数j, ICSj(F1)是比ICSj(F2)更好的转换序列,或者,如果不是,
——上下文是用户自定义转换的初始化(参见8.5、13.3.1.5和13.3.1.6)从返回类型F1到目的类型(即,类型)的标准转换序列实体被初始化)是一个比标准转换序列更好的转换序列将F2的返回类型转换为目标类型。[…]或者,如果不是,
- F1是非模板函数,F2是函数模板专门化,如果不是,则
- F1和F2是函数模板专门化,F1的函数模板更专门化
根据14.5.6.2中描述的部分排序规则,将F2的模板替换。
- 如何用参数值调用函数(仅在运行时已知)
- 从python中调用C++函数并获取返回值
- 当使用通配符和null指针调用函数时,对输出的说明
- 从R调用C++函数并对其进行集成时出错
- 使用QTreeView,如何通过调用函数只突出显示特定的行/列
- 如何在qt中从另一个类调用函数
- 在 COUT 语句中使用 COUT 调用函数
- 如何从线程中的不同模块调用函数?
- C++从函数指针数组调用函数
- 当 A 在 for 循环中调用函数 B 时,如何计算函数 A 的空间复杂度?
- 如何在 C/C++ 中从外部库调用函数
- 如何使用运算符在同一行中多次调用函数
- 是否可以创建一个从不同类调用函数的线程?
- 无法为类成员调用函数
- 如何从另一个标头 c++ 调用函数
- C++有什么方法可以在既不调用函数模板也不提供其模板参数的情况下引用函数模板?
- 如何只允许在调用函数 B 后调用函数 A?
- 我可以这样调用函数吗?
- 如何在 c++ 的类中递归调用函数方法?
- 为什么在指向对象的迭代器上调用函数不允许我更改对象本身?