C++模板通过指针的函数/常量指针的函数进行的部分专用化没有什么不同
C++ template partial specialization by a function of pointer / a function of const pointer are not different?
让我们考虑以下代码:
template <typename T>
class Foo
{};
template <typename T, typename U>
class Foo<T(*)(U* const)>
{};
template <typename T, typename U>
class Foo<T(*)(U*)>
{};
当我尝试编译它(ideone)时,它无法告诉我这两个模板专业化是相同的。这是令人惊讶的,因为通常U*
和U* const
是不同的东西(第二个是常量指针)。这里怎么了?
在确定函数的类型(通俗地称为其签名)时,会删除顶级cv限定符。
§8.3.5/5…函数的类型通过以下方式确定规则。。。生成参数类型列表后,任何顶级修改参数类型的cv限定符在形成函数类型。。。
对于函数指针或模板参数,没有特殊的规则可以使其无效。
你必须这样写:
template <typename T, typename U>
class Foo<T(*)(const U* )>
{};
相关文章:
- 如何正确编写指针函数声明?
- C++常规指针函数或模板
- 如何重新定义 C++ 指针函数?
- C++ 指向其他类函数的指针函数
- 指针到指针函数参数
- 将指向成员的指针函数传递到模板中
- C++ 在 none 常量指针函数中返回一个常量指针
- 如何使用指针函数编写/读取数组
- 是C 中的函数指针函数对象
- 如何从另一个类调用指向成员的指针函数
- 如何声明采用指向成员的指针函数的函数
- 如何构造一个以可变参数指针函数作为成员的类?
- c 通过值或指针函数语法
- 将typedef方法作为指针函数传递
- 从 Main 中的双指针函数打印出指针数组
- strcpy 对指针函数的引用
- 这是否仍然声明一种指针函数的别名?
- 将指向成员的指针函数与 std::shared_ptr 结合使用
- 'Incomplete type' 为标准::函数声明指向成员的指针函数模板参数时出错
- 从注入进程的 DLL 调用函数并更改指针函数的地址