2

我有一个我无法解决的问题。查找到目前为止我发现的所有内容。我的问题是,我在我的程序中创建了一个 dyn 库,想要 dlopen 并从该库中 dlsym 一个方法。

似乎 dlopen 有效,但 dlsym 向我返回错误“未定义符号:方法

其中“ method ”是我传递给 dlsym 的方法的名称。

这是我创建库的方式:

execl("/usr/bin/gcc", "gcc", "-fPIC", "-Wall", "-g", "-c", "userinput.c", NULL);

和:

execl("/usr/bin/gcc", "gcc", "-ggdb3", "-shared", 
      "-Wl,-soname,libuserinput.so.1", "-o", "libuserinput.so.1.0",
  "userinput.o", "-lc", NULL);

这应该可以工作,因为运行我的代码后有一个库。

我这样打开图书馆:

static void *my_load_dyn (const char *lib) {
static void *handle;
handle = dlopen ("./libuserinput.so.1.0", RTLD_NOW | RTLD_DEEPBIND);
if (handle == NULL) {
  printf ("error at dlopen(): %s\n", dlerror ());
  exit (EXIT_FAILURE);
}
return handle;
}

/* load func from dyn lib"*/
static void *my_load_func (void *handle, char *func) {
  void *funcptr = dlsym (handle, func);
  if (funcptr == NULL) {
    printf ("error at dlsym(): %s\n", dlerror ());
    exit (EXIT_FAILURE);
  }
  return funcptr;
}

并像这样调用这些函数:

void *libhandle;
void (*userMethod) (unsigned char *d);

libhandle = my_load_dyn(LIBUSERINPUT);
userMethod = my_load_func(libhandle, "testMethod");
(*userMethod)(d);

编辑:这是来自 userinput.c 的代码:

#include <stdio.h>
#include <unistd.h>
void testMethod(unsigned char *d)
{
d[0] = 'Z';
}

它是在我的程序中生成的,也在运行的程序中编译和链接

4

1 回答 1

0

我可以看到两个可能的问题

  • 代码有问题

    你确定你将你的声明method公共函数userinput.c吗?

    例如,如果您的方法已声明static,则无法从“外部”访问它。还有其他方法可以隐藏函数在库之外不被看到,但是如果没有看到任何代码就不可能判断你是否有这个问题。

  • 您的库的编译/链接已损坏

    例如,您似乎将头文件 ( userinput.h) 链接到生成的库中?

    我建议在问题解决之前使用正确的构建系统,然后切换到动态编译(例如使用make

于 2013-12-19T14:29:12.593 回答