指向模板化静态成员函数的指针向量
C++11 Vector of Pointers to Templated Static Member Function
假设我有一个这样的类:
struct MyStruct
{
template<typename T>
static int Func()
{
// Do something with the template parameter.
}
};
现在假设我想创建一个指向具有Func
原型的函数的指针向量。因为原型不依赖于模板参数,所以这应该是可能的。当然,我可以显式地将typedef
指向Func
,如下所示:
typedef int (* FuncPtr)(MyStruct * pointer);
然后,创建向量非常简单,如下所示:
std::vector<FuncPtr> FuncVector;
但是,我想避免两次声明Func
的原型。这可能吗?
使用decltype
:
std::vector<decltype(&MyStruct::Func<void>)> FuncVector;
代替FuncPtr
的typedef
,您可以这样做:
using FuncPtr = decltype(&MyStruct::Func<int>);
相关文章:
- QMetaObject invokeMethod的基于函数指针的语法
- C++-试图将函数指针推回到另一个CPP文件中的矢量时出错
- c++r值引用应用于函数指针
- 模板函数指针和lambda
- 是否可以将llvm::FunctionType转换为C/C++原始函数指针
- 带有类的函数指针
- () 函子后面的括号,而不是函数指针?
- 全局作用域中函数指针的赋值
- 使用"Task"函数指针队列定义作业管理器
- 将成员函数指针作为参数传递给模板方法
- 如何创建对象函数指针C++映射?
- 匹配函数指针作为模板参数?
- 通过函数指针定义类范围之外的方法
- 存储在类中的函数指针
- C++从函数指针数组调用函数
- 将返回值存储在函数指针数组的指针中是如何工作的?
- 整数键映射到头文件中的成员函数指针
- 从类成员函数到类 C 函数指针的转换
- 如何将内联匿名函数分配给C++函数指针
- 将字符缓冲区强制转换为函数指针