How to link using GCC without -l nor hardcoding path for a library that does not follow the libNAME.so naming convention?(对于不遵循 libNAME.so 命名约定的库,如何在不使用 -l 或硬编码路径的情况下使用 GCC 进行链接?)
问题描述
我有一个共享库,我希望使用 GCC 链接可执行文件.共享库有一个非标准名称,不是 libNAME.so 形式,所以我不能使用通常的 -l 选项.(它恰好也是一个 Python 扩展,因此没有lib"前缀.)
I have a shared library that I wish to link an executable against using GCC. The shared library has a nonstandard name not of the form libNAME.so, so I can not use the usual -l option. (It happens to also be a Python extension, and so has no 'lib' prefix.)
我可以将库文件的路径直接传递给链接命令行,但这会导致库路径被硬编码到可执行文件中.
I am able to pass the path to the library file directly to the link command line, but this causes the library path to be hardcoded into the executable.
例如:
g++ -o build/bin/myapp build/bin/_mylib.so
有没有办法链接到这个库而不导致路径被硬编码到可执行文件中?
Is there a way to link to this library without causing the path to be hardcoded into the executable?
推荐答案
:"前缀允许您为库指定不同的名称.如果你使用
There is the ":" prefix that allows you to give different names to your libraries. If you use
g++ -o build/bin/myapp -l:_mylib.so other_source_files
应该在您的路径中搜索 _mylib.so.
should search your path for the _mylib.so.
这篇关于对于不遵循 libNAME.so 命名约定的库,如何在不使用 -l 或硬编码路径的情况下使用 GCC 进行链接?的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持编程学习网!
本文标题为:对于不遵循 libNAME.so 命名约定的库,如何在不使用 -l 或硬编码路径的情况下使用 GCC 进行链接?
- STL 中有 dereference_iterator 吗? 2022-01-01
- 使用/clr 时出现 LNK2022 错误 2022-01-01
- 如何对自定义类的向量使用std::find()? 2022-11-07
- 静态初始化顺序失败 2022-01-01
- C++ 协变模板 2021-01-01
- Stroustrup 的 Simple_window.h 2022-01-01
- 近似搜索的工作原理 2021-01-01
- 与 int by int 相比,为什么执行 float by float 矩阵乘法更快? 2021-01-01
- 一起使用 MPI 和 OpenCV 时出现分段错误 2022-01-01
- 从python回调到c++的选项 2022-11-16