c++ - 如何选择 remove_reference 的特化

标签 c++ specialization partial-specialization

remove_reference 定义如下:

template< class T > struct remove_reference      {typedef T type;};
template< class T > struct remove_reference<T&>  {typedef T type;};
template< class T > struct remove_reference<T&&> {typedef T type;};   

当对于类型 T 实例化 remove_reference 时,选择模板适当特化的算法是什么?我不认为这是模板参数推导。我发现的其他事情甚至不太相关(ADL、重载解析等)

最佳答案

我们:

  1. 选择与模板参数匹配的特化。如果只有一个,你就选择那个。如果没有,则使用主要的。否则:

  2. 为每个特化合成一个函数并使用函数模板偏序规则。

在这种情况下,我们永远不必进入第二步。存在三种类型的相关类型:非引用、左值引用和右值引用。所以我们可以制作一个表格:

+---------------------------+-------------+--------------+
|                           | Matches T&? | Matches T&&? |
+---------------------------+-------------+--------------+
| remove_reference<int>     | No          | No           |
| remove_reference<char&>   | Yes, T=char | No           |
| remove_reference<float&&> | No          | Yes, T=float |
+---------------------------+-------------+--------------+

请注意 remove_reference<char&> 匹配remove_reference<T&&> . T&&这里只是对 T 的右值引用,它不是转发引用 - 转发引用只是一个函数模板参数,其类型是对模板参数的右值引用。这是一个类模板参数。即使在概念上与 T=char& , T&&将是 char&使用引用折叠规则,这不会发生。

在这三种情况中的每一种情况下,我们要么匹配零个特化 - 我们使用主模板 - 或者恰好匹配一个特化 - 在这种情况下我们使用该特定特化。

关于c++ - 如何选择 remove_reference 的特化,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/39907276/

相关文章:

C++ 子线程抛出异常

c++ - 三元运算符的返回类型是如何确定的?

c++ - 在程序可能性中将 O(n) 中的所有元素增加整数 x?

C++ 递归模板特化

c++ - 模板类模板成员的模板特化

C++:部分专用模板类型参数作为另一个模板类成员类型

c++ - 使用 Search 方法为普通类型 (int) 和指针的 const 创建数组类

c++ - 错误 : invalid use of incomplete type (Maybe a definition issue)

c++ - 将 Objective C++ 用于 WatchKit

C++ 特化,type_of 或只是 typeid