本地动态库

Local dynamic library

本文关键字:动态      更新时间:2023-10-16

马上,我想说我从未与动态库合作,因此我什至不了解它们如何正常工作。

我想运行一个满载的代码,在进行一些触发器(可能是用户交互)之后,我想加载特定的库并在该库中执行功能。最好之后关闭它。本质上允许我更改它并在运行时间重新加载它。

这是一个简单的动态库(称为 dynlib.so ,位于与主代码相同的目录中):

int getInt(int arg_0)
{
  return (arg_0 + 7);
}

这是主要程序:

#include <iostream>
#include <dlfcn.h>
int main() {
  void *lib_handle = dlopen("./dynlib.so", RTLD_LAZY | RTLD_NOW);
  if (!lib_handle) {
    fprintf(stderr, "%sn", dlerror());
    exit(EXIT_FAILURE);
  }
  typedef int (*func_ptr)(int);
  func_ptr func = (func_ptr)dlsym(lib_handle, "getInt");
  std::cout << func(13);
  dlclose(lib_handle);
}

我正在使用: g -std = c 11 -ldl loadlibtest.cpp -o main 。。

我要捕获的错误是 ./libshared.so:文件太短在我的if (!lib_handle) {中。

它对我来说很好。我已经用

编译了dynlib.so
$ gcc dynlib.c -fPIC -shared -o dynlib.so

(显然,您需要用extern "C"将其编译为C或C ,以避免名称Mangling)。

,我需要将-ldl放在源文件之后的g++调用中。

GCC:4.8.5;G :5.3.0


dlsym也可能失败,从void*到功能指针的铸造是从技术上讲。您应该将其基于使用manpage(为您的功能修改):

       dlerror();    /* Clear any existing error */
       /* Writing: func = (int (*)(int)) dlsym(handle, "getInt");
          would seem more natural, but the C99 standard leaves
          casting from "void *" to a function pointer undefined.
          The assignment used below is the POSIX.1-2003 (Technical
          Corrigendum 1) workaround; see the Rationale for the
          POSIX specification of dlsym(). */
       *(void **) (&func) = dlsym(handle, "getInt");
       if ((error = dlerror()) != NULL)  {
           fprintf(stderr, "%sn", error);
           exit(EXIT_FAILURE);
       }

在一些很好的答复之后,我发现了我做错了什么。

1)我没有为我的库函数使用extern" c",因此 dlsym 无法找到该功能。

2)我不知道必须编译动态库&lt;&lt;我很愚蠢。

我仍然想知道是否有一种方法可以使用未编译的代码作为库,但是我的最初问题得到了解决,这要归功于所有人。