将成员函数指针转换为普通函数指针

时间:2015-12-02 16:22:39

标签: c++ templates pointers function-pointers variadic-templates

我正在使用可变参数调用模式shown here。它适用于普通的C函数。但我希望将它与成员函数和显式地将实例指针作为第一个参数的元组一起使用。

我试过这样的事情:

template<typename Ret, typename C, typename...Args>
int methodWrapper(const string& name, Ret (C::*func)(Args...), lua_State* L)
{
    return wrap<Ret,C*,Args...>::wrapFunc(name, func, L);
}

但它无法转换指针类型:

cannot initialize a parameter of type 'void (*)(Object *, float, float)' with an lvalue of type 'void (Object::*)(float, float)'

在这种情况下,wrap函数是模板化的,因此指针的类型必须完全匹配。

template<typename Ret, typename...Args>
struct wrap{
    static int wrapFunc(const string& name, Ret (*func)(Args...), lua_State* L)
    {
        ...
    }
};

如何将成员函数指针显式转换为以this指针作为第一个参数的普通函数指针?

编辑:对于那些将我链接到this question的人来说,情况并不相同。我不必将普通的C函数指针传递给具有特定接口的现有API。我不是试图将成员函数绑定到特定对象。这个问题也不涉及可变调用或元组。

1 个答案:

答案 0 :(得分:0)

std::mem_fn这样做。

为了使模板匹配:我必须显式地将args元组声明为Class指针,后跟参数pack:

template<typename C, typename...Args>
struct wrapMethod<void,C,Args...>{
    static int wrap(const string& name, void (C::*func)(Args...), lua_State* L)
    {
        tuple<C*, Args...> args = cargs<C*,Args...>::getCArgs(L, name);

        //Return type (first template parameter) cannot be inferred.
        variadic_call<void>(mem_fn(func), args);

        return 0;
    }
};