5

我有一组回调类,用于处理带有可变数量参数的回调。现在我有大约 6 个不同的实例来处理不同数量的参数。有没有办法让一个实例可以处理可变数量的参数?最终,我希望每个参数都是 POD 类型或类指针或结构指针。有任何想法吗?

template <class T>
class kGUICallBackPtr
{
public:
    kGUICallBackPtr() {m_obj=0;m_func=0;}
    void Set(void *o,void (*f)(void *,T *));
    inline void Call(T *i) {if(m_func) m_func(m_obj,i);}
    inline bool IsValid(void) {return (m_func!=0);}
private:
    void *m_obj;
    void (*m_func)(void *,T *);
};


template <class T,class U>
class kGUICallBackPtrPtr
{
public:
    kGUICallBackPtrPtr() {m_obj=0;m_func=0;}
    void Set(void *o,void (*f)(void *,T *,U *));
    inline void Call(T *i, U *j) {if(m_func) m_func(m_obj,i,j);}
    inline bool IsValid(void) {return (m_func!=0);}
private:
    void *m_obj;
    void (*m_func)(void *,T *,U *j);
};
4

4 回答 4

5

语言本身还没有,但 C++0x 将支持可变参数模板

于 2008-09-30T20:18:38.223 回答
3

C++0x variatdic 模板是你最好的选择,但你也需要一段时间才能使用它们。

如果您现在需要类型序列,请查看 MPL 的类型向量以及其他类型序列类型。它是Boost库的一部分。它允许您提供一个类型序列的模板参数,而不仅仅是一个类型。

于 2008-10-01T05:55:59.380 回答
0

通过使用Boost Bind来回避这个问题怎么样?您可以让您的代码接受单个参数,或者根本不接受,并在调用站点绑定您需要的参数。

于 2008-10-01T00:07:48.623 回答
0

我的第一选择是使用 boost::bind、boost::function 或 std::bind/std::function 和/或 c++11 lambda 来实现您的目标。但是,如果您需要滚动自己的仿函数,那么我将使用 boost fusion 创建一个采用单个模板参数的“融合仿函数”。

http://www.boost.org/doc/libs/1_41_0/libs/fusion/doc/html/fusion/functional/generation/functions/mk_fused.html

最终,所有这些库都使用预处理器宏来枚举所有可能的选项来解决缺少可变模板的问题。

于 2012-08-02T04:08:24.267 回答