我有一个
的程序结构静态库(ACE)
静态库(common.a)
动态库插件1(1.so)
插件2(2.so)和可执行文件
plugin1, plugin2 and executable
全部同时使用common.a
和libACE.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.
这样的选项,但它仍然找不到这个符号。任何想法?
答案 0 :(得分:0)
它就在那里,但插件无法找到它!
不,符号不那里!
或者更确切地说,该符号具有内部链接(t
),并且在与其链接的ELF图像之外不可见或不可用。全局可见符号具有外部(T
)链接。
符号与t
链接的最可能原因是该符号在源级别具有__attribute__((visibility("hidden")))
。文档here。
为什么ACE开发人员会这样标记,我不知道。