开发者

Linking dependency

开发者 https://www.devze.com 2023-03-24 04:50 出处:网络
Start with shared library libA.so that is in /some/lib. I build library (libB.so) that depends on a capability in libA.so. So, when creating libB.so, I include -L/some/lib -lA on the g++ command line.

Start with shared library libA.so that is in /some/lib. I build library (libB.so) that depends on a capability in libA.so. So, when creating libB.so, I include -L/some/lib -lA on the g++ command line. libB.so will also reside in /some/lib.

Now, I'm building an executable that will use libB.so. I provide the expected -L/some/lib and -lB to the g++ linker. But I get an error because i开发者_如何转开发t can't find "libA.so". If I add "-lA" to the linker line, the program links.

I don't understand why it doesn't find "libA.so". I certainly don't understand why including "-lA" on the linker line lets it find it. It appears to already know that it needs libA.so, and libA.so is in the same path as libB.so.

Can someone explain this? I don't like the idea of having to explicitly put "-lA" in every executable that wants to link libB.so. Did I do something else wrong?


While you are linking against libB only, the linker looks for libA, but cannot find it, because it isn't in a findable path for the linker/loader. You have to set LD_LIBRARY_PATH (and/or LD_RUN_PATH) during the linking stage, or otherwise link libB with -rpath /some/lib.

Just pretend for a minute that libB is itself an executable, let's call it foo. You couldn't just say ./foo at the command line because libAwouldn't be found (check ldd foo to examine the loader paths). Instead, you need

LD_LIBRARY_PATH=/some/lib ./foo

or you need to compile with rpath. (In g++, you'd say g++ -Wl,-rpath,/some/lib ... to pass the option to the linker.) The same load-time resolution process applies to dynamic libraries themselves.

0

精彩评论

暂无评论...
验证码 换一张
取 消