首页 >后端开发 >C++ >为什么 `const char*` 函数重载优于 `const char (&)[N]` 模板函数?

为什么 `const char*` 函数重载优于 `const char (&)[N]` 模板函数?

Mary-Kate Olsen
Mary-Kate Olsen原创
2024-11-26 18:04:08746浏览

Why Does a `const char*` Function Overload Prevail Over a `const char (&)[N]` Template Function?

重载冲突:指针衰减与模板推导

问题:

为什么带有类型参数的函数const char* 优先于具有 const char 类型参数的函数模板(&s)[N] 当两者同等适用时?

根本原因:

歧义源于相对的转化成本。重载解析有利于需要较少转换操作的函数。数组实际上是指向其第一个元素的指针,这意味着数组到指针的转换成本低于声明基于数组的函数模板。

标准解释:

根据C标准([over.match.best]/(1.3), (1.6)):

  • 非专用函数优于专用函数模板。
  • 如果两个转换具有相同的排名,则它们无法区分。

在这种情况下:

  • 从数组到指针的转换是具有精确匹配等级的左值转换。
  • 排除左值转换,转换等级并不重要。
  • 因此,两种转换序列都不是更好,导致歧义和选择 char const* 重载。

可能解决方法:

要优先考虑基于模板的函数,请将第二个重载也定义为函数模板:

template <typename T>
auto foo(T s)
    -> std::enable_if_t<std::is_convertible<T, char const*>{}>
{
    std::cout << "raw, size=" << std::strlen(s) << std::endl;
}

此部分排序可确保基于模板的函数是适用时选择。

以上是为什么 `const char*` 函数重载优于 `const char (&)[N]` 模板函数?的详细内容。更多信息请关注PHP中文网其他相关文章!

声明:
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn