Linux庫多重依賴


源文件:

//world.cpp
#include <stdio.h>

void world(void)
{
    printf("world.\n");
}
//hello.cpp
#include <stdio.h>

void world(void);

void hello(void)
{
    printf("hello\n");
    world();
}
//test.cpp

void hello(void);

int main(void)
{
    hello();
    return 0;
}

 一、動態庫多重依賴

(1)編譯word動態庫

g++ -shared -fPIC world.cpp -o libworld.so

(2)編譯hello動態庫

g++ -shared -fPIC hello.cpp -o libhello.so

ldd libhello.so

查看libhello.so的依賴庫,沒有看到依賴libword.so

g++ -shared -fPIC hello.cpp -o libhello.so -L ./ -lworld

ldd libhello.so

再次查看libhello.so的依賴庫,看到了依賴庫libword.so

上圖顯示libworld.so not found,如果臨時增加鏈接動態庫的路徑,輸入如下命令

export LD_LIBRARY_PATH=./

ldd libhello.so

查看libhello.so的依賴庫,顯示了依賴庫libword.so的路徑

先清除鏈接動態庫路徑

export LD_LIBRARY_PATH=

(3)編譯可執行文件test

g++ test.cpp -o a.out -L ./ -lhello

提示找不到libhello.so的依賴庫libworld.so,即使編譯libhello.so時已經指定了libworld.so,這點和windows不一樣

g++ test.cpp -o a.out -L ./ -lhello -lworld -Wl,-rpath ./

編譯通過,得到可執行文件a.out,運行成功

二、動態庫靜態庫多重依賴

(1)編譯word靜態庫

g++ -c world.cpp

ar -cr libworld.a world.o

(2)編譯hello動態庫

g++ -shared -fPIC hello.cpp -o libhello.so -L ./ -lworld

編譯報錯,因為world也必須使用-fPIC,重新編譯

(3)編譯可執行文件

g++ test.cpp -o a.out -L ./ -lhello -Wl,-rpath ./

三、靜態庫多重依賴

(1)編譯world靜態庫

g++ -c world.cpp

ar -cr libworld.a world.o

(2)編譯hello靜態庫

g++ -c hello.cpp

ar -cr libhello.a hello.o

(3)編譯可執行文件

g++ test.cpp -o a.out -L ./ -lworld -lhello

因為靜態庫的依賴有順序,被調用庫應該放在調用庫后面,動態庫沒有依賴順序,正確輸入如下

g++ test.cpp -o a.out -L ./ -lhello -lworld

 (4)靜態庫包含靜態庫

 


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM