C++ 从静态库打开动态库linux C++;

C++ 从静态库打开动态库linux C++;,c++,linux,static-libraries,dlopen,C++,Linux,Static Libraries,Dlopen,我有一个linux应用程序,它链接到一个静态库(.a),该库使用dlopen函数加载动态库(.so) 如果我将静态库编译为动态库并将其链接到应用程序,dlopen将按预期工作,但如果我如上所述使用它,则不会 静态库不能使用dlopen函数加载共享库吗 谢谢。您尝试执行的操作应该没有问题: 附录c: #include "staticlib.h" #include "stdio.h" int main() { printf("and the magic number is: %d\n",doSo

我有一个linux应用程序,它链接到一个静态库(.a),该库使用dlopen函数加载动态库(.so)

如果我将静态库编译为动态库并将其链接到应用程序,dlopen将按预期工作,但如果我如上所述使用它,则不会

静态库不能使用dlopen函数加载共享库吗


谢谢。

您尝试执行的操作应该没有问题:

附录c:

#include "staticlib.h"
#include "stdio.h"
int main()
{
  printf("and the magic number is: %d\n",doSomethingDynamicish());
return 0;
}
staticlib.h:

#ifndef __STATICLIB_H__
#define __STATICLIB_H__

int doSomethingDynamicish();

#endif
staticlib.c:

#include "staticlib.h"
#include "dlfcn.h"
#include "stdio.h"
int doSomethingDynamicish()
{
  void* handle = dlopen("./libdynlib.so",RTLD_NOW);
  if(!handle)
  {
    printf("could not dlopen: %s\n",dlerror());
    return 0;
  }

  typedef int(*dynamicfnc)();
  dynamicfnc func = (dynamicfnc)dlsym(handle,"GetMeANumber");
  const char* err = dlerror();
  if(err)
  {
    printf("could not dlsym: %s\n",err);
    return 0;
  }
  return func();
}
dynlib.c:

int GetMeANumber()
{
  return 1337;
}
并建立:

gcc -c -o staticlib.o staticlib.c
ar rcs libstaticlib.a staticlib.o
gcc -o app app.c libstaticlib.a -ldl
gcc -shared -o libdynlib.so dynlib.c
第一行构建库
第二行将其打包到一个静态库中
第三个构建测试应用程序,在新创建的静态链接中进行链接,再加上linux动态链接库(libdl)
第四行构建即将动态加载的共享库

输出:

./app
and the magic number is: 1337

描述“不会”是什么意思
errno
dlopen之后的代码?仅供参考:为了构建动态链接库,我必须使用以下命令:
gcc-shared-o libdynlib.so dynlib.c