关于 C 函数的封装和调用。

我从这篇中文博客[http://chenyufei.info/blog/2011-02-28/wrap-c-function-closure-gcc-nested-function/]得到了这个问题。 作者想在C语言中使用闭包,他发现GCC有嵌套函数(和闭包)的功能。 例如:

typedef int (*func_t)(int arg);

int foo(int a) {

    return a + 1;

}

func_t create_wrap_function(func_t f) {

    int wrapped(int arg) {

        // call original function

        int val = f(arg);

        fprintf(log_func_call, "arg: %d ret: %d", arg, val);

        return val;
    }

    return wrapped;
}

但这不是常见的解决方案。create_wrap_function具有固定的函数格式,因为func_t限制了其格式。

正如我们所知道的,Lua具有闭包,并且也可以调用C函数。 我想要实现的是: 我们想要调用的函数是foo1和foo2,它们具有不同类型的参数和返回值。

int foo1(int a) {
    ...
    return intValue;
}

double foo2(char* str, double a) {
   ...
   return dblValue;
}

在C客户端中,调用函数如下:

lua_returnValue returnValue1 = Do_Lua_Wrap(__FILE__, __LINE__, foo1, 1);
lua_returnValue returnValue2 = Do_Lua_Wrap(__FILE__, __LINE__, foo2, "string data", 1.2345);

在Do_Lua_Wrap中,它将传递foo1和1到Lua函数,然后像正常过程一样调用foo1函数。 然后将foo2和一个char*和一个double值传递到Lua函数中,然后像正常过程一样调用foo2函数。 在Lua函数中,它可以记录有关FILELINE的信息,并写入一些有关函数参数的额外日志。

但是我不知道如何在C和Lua中编写Do_Lua_Wrap函数, 是否可能?

如果可能,您能给我一些建议吗?

原文链接 https://stackoverflow.com/questions/5144542

点赞
stackoverflow用户1491
stackoverflow用户1491

你显然对可变参数函数很感兴趣,但问题在于确定要推送到 Lua 栈中的参数类型。我会建议几种方法:

  1. 第一种方法是包含一个格式化字符串,如printf家族或在高级语言中经常使用的二进制打包格式。例如,看看lpack Lua 模块中使用的格式模式。关键是要扫描格式字符串以确定提供了多少个和什么类型的参数。

  2. 或者,您可以实现一个variant类型。每个参数都需要包装在这样的结构中。此外,总参数数需要作为第一个参数提供。

  3. 最后,您可以使用两个数组传递参数,而不是使用可变参数函数。第一个数组将包含枚举类型,对应于第二个数组中的void *指针的目标。这种方法需要客户端代码进行最多的维护,但非常干净。还需要一个指定数组长度或在一个或两个数组末尾使用哨兵值的参数。

希望这些方法中的其中一个适合您。就个人而言,我会选择第一种选项,并使用lpack代码作为指南。它最接近您问题中指定的函数签名。

2011-03-01 14:59:12