在 C++ 11 中使用来自模板类型的成员函数指针创建方法参数
Create method argument with member function pointer from template types in C++ 11
我想实现以下目标:
template <typename F>
class MyTemplate {
public:
void SomeMethod(F f) {
//...
}
template <typename C, typename O>
void SomeMethod(C::*F f, O& o) { // this does not work, I want a member function pointer here
//...
}
};
static void StaticFunction(int);
class SomeClass {
public:
void MemberMethod(int);
};
MyTemplate<void(int)> mt;
mt.SomeMethod(StaticFunction);
SomeClass SomeClassInstance;
mt.SomeMethod(&SomeClass::MemberMethod, SomeClassInstance); // I want to call it like this
我想创建一个带有函数类型参数的模板。该模板应该 'create' 重载 C 风格或静态函数指针以及成员函数。
如何从应该用于声明模板实例的自由函数类型创建成员函数类型?
我希望能够将模板与以下类型一起使用:
- 无效(无效)
- 无效(整数)
- 整数(无效)
- 整数(整数)
- int(int, int, int, int)
- void(int, int, int, int)
- 等等
这里是dyp提供的答案:
template <typename F>
class MyTemplate {
public:
void SomeMethod(F f) {
//...
}
template <typename C, typename O>
void SomeMethod(F C::* f, O& o) { // this does work
//...
}
};
static void StaticFunction(int) {}
struct SomeClass {
public:
void MemberMethod(int) {}
};
int main()
{
MyTemplate<void(int)> mt;
mt.SomeMethod(StaticFunction);
SomeClass SomeClassInstance;
mt.SomeMethod(&SomeClass::MemberMethod, SomeClassInstance); // I want to call it like this
}
我想实现以下目标:
template <typename F>
class MyTemplate {
public:
void SomeMethod(F f) {
//...
}
template <typename C, typename O>
void SomeMethod(C::*F f, O& o) { // this does not work, I want a member function pointer here
//...
}
};
static void StaticFunction(int);
class SomeClass {
public:
void MemberMethod(int);
};
MyTemplate<void(int)> mt;
mt.SomeMethod(StaticFunction);
SomeClass SomeClassInstance;
mt.SomeMethod(&SomeClass::MemberMethod, SomeClassInstance); // I want to call it like this
我想创建一个带有函数类型参数的模板。该模板应该 'create' 重载 C 风格或静态函数指针以及成员函数。 如何从应该用于声明模板实例的自由函数类型创建成员函数类型?
我希望能够将模板与以下类型一起使用:
- 无效(无效)
- 无效(整数)
- 整数(无效)
- 整数(整数)
- int(int, int, int, int)
- void(int, int, int, int)
- 等等
这里是dyp提供的答案:
template <typename F>
class MyTemplate {
public:
void SomeMethod(F f) {
//...
}
template <typename C, typename O>
void SomeMethod(F C::* f, O& o) { // this does work
//...
}
};
static void StaticFunction(int) {}
struct SomeClass {
public:
void MemberMethod(int) {}
};
int main()
{
MyTemplate<void(int)> mt;
mt.SomeMethod(StaticFunction);
SomeClass SomeClassInstance;
mt.SomeMethod(&SomeClass::MemberMethod, SomeClassInstance); // I want to call it like this
}