使用可变参数模板键入给定成员函数指针的类型推导
Type deduction given member function pointer with variadic templates
>假设我有一个成员函数指针,我如何编写自动推断给定模板签名参数的代码:
template<typename T> class Foo {};
template<typename R, typename C, typename... A>
class Foo<R(C, A...)> { };
对于 C 和 R,没有问题,因为类似的东西可以解决问题:
template<typename R, typename C, typename... A>
R deduce_R_type(R(C::*)(A...));
template<typename R, typename C, typename... A>
C deduce_C_type(R(C::*)(A...));
然后我实际上可以将其插入 Foo 实例化,但如何推断来自模板可变参数部分的类型?
Foo<
decltype(deduce_R_type(&SomeClass::SomeFunction)) (
decltype(deduce_C_type(&SomeClass::SomeFunction)), ___ ??? ___)> instance
你至少需要一个助手和类似 std::tuple
:
template<typename R, typename C, typename... A>
std::tuple<A...> deduce_A_tuple(R(C::*)(A...));
template<typename R, typename C, typename T>
struct FooHelper;
template<typename R, typename C, typename... A>
struct FooHelper< R, C, std::tuple<A...> >
{
typedef Foo< R( C, A... ) > type;
};
然后您可以使用:
FooHelper< decltype(deduce_R_type(&SomeClass::SomeFunction)),
decltype(deduce_C_type(&SomeClass::SomeFunction)),
decltype(deduce_A_tuple(&SomeClass::SomeFunction)) >::type instance;
现场示例
正如用户 DyP 指出的那样,无论如何,当您必须使用助手时,它可能会简单得多:
template<typename>
struct FooHelper;
template<typename R, typename C, typename... A>
struct FooHelper< R (C::*)(A...) >
{
using type = Foo< R( C, A... ) >;
};
并将其用作
FooHelper< decltype(&SomeClass::SomeFunction) >::type instance;
相关文章:
- 如何使用指针传递给函数的数组中对象的函数成员
- c++构造函数成员初始化:传递参数
- 创建 std::函数,它返回具有函数成员值的变量.分段错误
- 如何在C++通过公共函数访问私有函数成员?
- 解释了构造函数成员初始化列表
- 调用std::函数成员时内存损坏
- 是否可以为模板类的模板函数成员设置别名?
- 捕获 lambda 函数C++成员变量
- 构造函数成员初始值设定项跨成员列出,安全吗?
- 获取与在模板参数中传递的函数成员类型相同的类
- 如何从公共函数成员访问地图私有成员
- C 构造函数成员分配优化
- 使用命名空间进行函数成员定义
- 函数成员作为 CUDA 内核的参数
- 模板基类函数成员的别名
- 函数成员中用于void和继承的enable_if
- 头文件中是否定义了一个很长的Class函数成员
- 类内/构造函数成员初始化
- 使用指向部分专用函数成员的指针自动填充向量
- 指向函数成员的指针