调用无效的函数指针

Invalid function pointer called

本文关键字:指针 函数 无效 调用      更新时间:2023-10-16

我使用一个外部库(HarfBuzz),它以"调用无效函数指针"终止。

这是由以下代码引起的(减少到绝对最小):

typedef void (*hb_destroy_func_t) (void *);
void _do_nothing(void) { }
void test() {
    hb_destroy_func_t func = (hb_destroy_func_t) _do_nothing;
    void* arg = 0;
    func(arg);
}
EMSCRIPTEN_BINDINGS(foobar) {
    emscripten::function("test", &test);
}

现在我通过改变_do_nothing函数来解决这个问题:

void doNothing(void *) { }

由于它在一个外部库中,我做而不是想要更改源代码。我想知道是否有机会"教"emscripten处理这种情况。

您肯定不希望Emscripten "处理这种情况"。通过指向不兼容类型的函数的指针调用函数是未定义的行为(Emscripten可以可靠地报告它,因为它根据函数指针的类型将它们存储在单独的表中)。

你应该只提交一个bug,并要求库的开发人员在他们的代码中修复它。

这完全属于未定义行为的范畴:对于将函数指针强制转换为不同函数类型的结果,您唯一可以安全地做的事情就是将其强制转换回原始类型。此外,没有办法检查函数指针并找出它的原始类型,甚至它的当前类型是否与原始类型匹配。(包含函数指针和额外类型信息的数据结构可能会有所帮助)

一些平台可能提供更强的保障;依赖于此是不可移植的。更多的平台可能会让它在实践中发挥作用;依赖于此很可能在未来的编译器升级中导致中断,因为它们在存在未定义行为的情况下优化得更有效。