我想存储函数的void指针以及它们的类型

I want to store void pointers to functions along with the type of them

本文关键字:类型 void 存储 函数 指针      更新时间:2023-10-16

我正在尝试使vector保存指向函数的void指针,稍后将顺序调用。
假设我有三个函数。int a(), void b();, bool c();

向量是vector<void *> vec;

和我的函数存储指向函数的指针。

void registerFunction(void *func)
{
    vec.push_back(func);
}

现在我的问题是当尝试调用存储的所有函数时,因为它们都是void指针,我只是不能在不知道它们的类型的情况下调用函数。

所以我的问题是……是否有任何方法来存储符号类型,以便我可以将它们与各自的指针相关联,然后在调用函数的void指针时进行类型转换?

注意:函数不会总是类型,例如,void (*)(),我也想添加方法,因此ie。void (someclass::)()。是不是要求太多了?它会起作用吗?

不能将函数指针转换为void*。这是不允许的

如果所有的函数都可以用零参数调用,你不关心返回类型,你可以使用std::vector<std::function<void()>> (function也可以在Boost和TR1中找到,如果你的c++标准库不支持它)。

但是,如果我没记错的话,在c++ 11 std::function实现中不允许返回类型转换,在这种情况下,您可能需要以下内容:

template <typename T>
struct ignore_result_impl
{
    ignore_result_impl(T fp) : fp_(fp) { }
    void operator()() { fp_(); }
    T fp_;
};
template <typename T>
ignore_result_impl<T> ignore_result(T fp)
{
    return ignore_result_impl<T>(fp);
}
int g() { return 42; }
std::function<void()> f(ignore_result(g));

(在Boost实现中,我知道您可以直接使用function<void()>,但我很确定这在c++ 11中不再允许。我可能是错的,如果有人知道,我希望在评论中澄清。

void*不能安全地用作指向函数的泛型指针类型(尽管您可能能够避开它)。

但是,任何函数到指针的值都可以转换为另一种指针到函数的类型,然后再转换回来,而不会丢失信息。因此,您可以使用,例如,void (*)()(指向返回void且不接受参数的函数的指针)作为指向函数的泛型指针类型。

至于存储类型,我不确定这是否可能。如果可能性有限,可以使用枚举类型和switch语句。

只要所有函数都遵循相同的类型签名,就可以将void指针强制转换回该类型。

一个更好的解决方案是定义函数的类型:
typedef int(*fun_ptr)();
vector<fun_ptr> vec;