模板化函数指针

时间:2010-09-16 14:50:04

标签: c++ templates pointers function

我有一种方法来调用类的延迟函数:

//in MyClass declaration:
typedef void (MyClass::*IntFunc) (int value);
void DelayedFunction (IntFunc func, int value, float time);
class TFunctorInt
{
public:
    TFunctorInt (MyClass* o, IntFunc f, int v) : obj (o), func (f), value (v) {}
    virtual void operator()();
protected:
    MyClass* obj;
    IntFunc func;
    int value;
};
//in MyClass.cpp file:
void MyClass::DelayedFunction (IntFunc func, int value, float time)
{
    TFunctorBase* functor = new TFunctorInt (this, func, value);
    DelayedFunctions.push_back (TDelayedFunction (functor, time)); // will be called in future
}
void MyClass::TFunctorInt::operator()()
{
    ((*obj).*(func)) (value);
}

我想制作模板仿函数。第一个问题是:

template <typename T>
typedef void (MyClass::*TFunc<T>) (T param);

导致编译器错误:“typedef'的模板声明”。 什么可能是解决方案?

PS:代码基于http://www.coffeedev.net/c++-faq-lite/en/pointers-to-members.html#faq-33.5

1 个答案:

答案 0 :(得分:10)

C ++中没有模板typedef。 C ++ 0x中有这样的扩展。在此期间,做

template <typename T>
struct TFunc
{
    typedef void (MyClass::*type)(T param);
};

并在您使用TFunc<T>::type时使用typename(如果在依赖的上下文中,则前缀为TFunc<T>