本文介绍了如何链接使用GCC没有-l或硬编码路径的库不遵循libNAME.so命名约定?的处理方法,对大家解决问题具有一定的参考价值,需要的朋友们下面随着小编来一起学习吧!

问题描述

我有一个共享库,我想链接一个可执行文件使用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.

这篇关于如何链接使用GCC没有-l或硬编码路径的库不遵循libNAME.so命名约定?的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持!

08-23 02:37