从静态库构建共享库

Building shared library from static libraries

我已经编写了一些代码作为 boost::asio 的包装器,我正在寻找一种方法将其打包为共享对象 (.so),以供我正在使用的某些应用程序使用继续工作,但是我想从 boost 库中删除所有依赖项(主要是因为它们是自定义编译的,并且可能会与默认的预构建 boost 库发生冲突)。我正在将我的代码链接到这些特殊增强库的静态版本,但是,链接器提供以下错误:

g++ -D_GLIBCXX_USE_CXX11_ABI=0 -I/path_to_boost_headers -Wall -fPIC -o build/obj.o -c include/source.cpp 
g++ -D_GLIBCXX_USE_CXX11_ABI=0 -shared -Wl,-soname,libobj.so.1 -o lib/libobj.so.1 build/obj.o -lc /project_path/lib/libboost_serialization.a /project_path/lib/libboost_wserialization.a /project_path/lib/libboost_system.a
/usr/bin/ld: /home/joao/Work/ASBG/code/cpp/extra/socket/lib/libboost_system.a(error_code.o): relocation R_X86_64_PC32 against symbol `_ZN5boost6system16generic_categoryEv' can not be used when making a shared object; recompile with -fPIC
/usr/bin/ld: final link failed: Bad value
collect2: error: ld returned 1 exit status

如果我没记错的话,默认情况下boost库是用-fPIC编译的。即便如此,我在编译 boost 时添加了标志并替换了库:相同的输出。

尝试将 -Wl,--whole-archive-Wl,--no-whole-archive 放在静态库周围。

未经测试,但像这样的东西可以工作:

g++ -D_GLIBCXX_USE_CXX11_ABI=0 -shared -Wl,-soname,libobj.so.1 \
  -o lib/libobj.so.1 build/obj.o -lc \
  -Wl,--whole-archive \
  /project_path/lib/libboost_serialization.a \
  /project_path/lib/libboost_wserialization.a \
  /project_path/lib/libboost_system.a \
  -Wl,--no-whole-archive

备注:

  • --whole-archive 选项强制链接器查看所有符号,而不仅仅是未解析的符号。 Linux上有弱符号和强符号的概念。我在this answer.
  • 里写了解释
  • 我觉得Link a static lib into a shared lib?和你的问题很相似

(另请注意,将动态库和共享库混合使用可能不是一个好主意。您最终可能会遇到合并的缺点,这与您的简化想法背道而驰。但是,我不知道全貌。只是意见。)