动态库加载链接到静态库

时间:2012-06-29 08:14:50

标签: c++ plugins linker shared-libraries static-libraries

我有一个

的程序结构
  

静态库(ACE)

     

静态库(common.a)

     

动态库插件1(1.so)

     

插件2(2.so)和可执行文件

plugin1, plugin2 and executable全部同时使用common.alibACE.a 按照此处的教程:http://www.yolinux.com/TUTORIALS/LibraryArchives-StaticAndDynamic.html

我只在编译可执行文件时链接这两个静态库,如下所示:

g++  -g -DUNIX -DLINUX   -Wall -D__NUMBER_FIELD_ID__ -I/opt/ACE_wrappers -Ilib/ -I. -I./common -I./common/lib -I../inc -I/opt/pct/pctlib/inc -o acs_d acs_d.o  -L../lib  -Wl,--export-dynamic -rdynamic -Wl,--whole-archive /opt/ACE_wrappers/ace/libACE.a  common/libcommon_d.a -Wl,--no-whole-archive -ldl -lrt -lpthread

关键是,当我使用dlopen打开这两个插件时,一个成功,一个失败 成功的一个使用更多的ACE函数,错误是抱怨未定义的符号,如下所示:

[CModuleMgr] loadCModule(): Errors occurred when opening the module. nCModuleId[1] pLibHandle[(nil)] sCModulePath[/opt/acs/adapter/libadapter_d.so] sError[/opt/acs/adapter/libadapter_d.so: undefined symbol: _ZN17ACE_Event_Handler10set_handleEi]

对于主程序,我尝试使用命令nm来查找符号

$ nm acs_d | grep _ZN17ACE_Event_Handler10set_handleEi
000000000048f240 t _ZN17ACE_Event_Handler10set_handleEi

它就在那里,但插件无法找到它!我使用了像-Wl,--export-dynamic -rdynamic -Wl,--whole-archive.这样的选项,但它仍然找不到这个符号。任何想法?

1 个答案:

答案 0 :(得分:0)

  

它就在那里,但插件无法找到它!

不,符号那里!

或者更确切地说,该符号具有内部链接(t),并且在与其链接的ELF图像之外不可见或不可用。全局可见符号具有外部(T)链接。

符号与t链接的最可能原因是该符号在源级别具有__attribute__((visibility("hidden")))。文档here

为什么ACE开发人员会这样标记,我不知道。