1.testa.c
[cpp] view plain copy #include <stdio.h> void Test_a() { PRintf("This is Test_a!"); } 2.%20testb.c[cpp]%20view%20plain%20copy%20#include <stdio.h> void Test_b() { printf("This is Test_b!"); } 3.%20testc.c[cpp]%20view%20plain%20copy%20#include <stdio.h> void Test_c() { printf("This is Test_c!"); } 4.%20testh.h[cpp]%20view%20plain%20copy%20void Test_a(); void Test_b(); void Test_c();5.%20main.c
[cpp]%20view%20plain%20copy%20#include "testh.h" int main() { Test_a(); Test_b(); Test_c(); return 0; } 现在,我们将三个test函数编译为一个动态库,使用一下命令:[plain]%20view%20plain%20copy%20gcc -fPIC -shared testa.c testb.c testc.c -o libtest.so 生成了libtest.so文件,其中,命令中-shared该选项指定生成动态连接库(让连接器生成T类型的导出符号表,有时候也生成弱连接W类型的导出符号),不用该标志外部程序无法连接。相当于一个可执行文件-fPIC:表示编译为位置独立的代码,不用此选项的话编译后的代码是位置相关的所以动态载入时是通过代码拷贝的方式来满足不同进程的需要,而不能达到真正代码段共享的目的。
然后,通过通过命令
[plain]%20view%20plain%20copy%20gcc main.c -L. -ltest -omain 编译生成应用程序main,其中命令中-L.:表示要连接的库在当前目录中-ltest:编译器查找动态连接库时有隐含的命名规则,即在给出的名字前面加上lib,后面加上.so来确定库的名称
%20 %20我们知道一个程序要想在内存中运行,除了编译之外还要经过链接和装入这两个步骤。当然linux中动态链接也是经过这三个过程。Linux%20使用这个ld-linux.so*中的来装载(其实这只是一个链接)其他库。所以这个库必须放在linux中/lib下。对于其他,通常我们共享库放在/lib这个路径下,而且也是系统默认的搜索路径。Linux共享库的搜索路径先后顺序:1、编译目标代码时指定的动态库搜索路径:在编译的时候指定-Wl,-rpath=路径2、环境变量LD_LIBRARY_PATH指定的动态库搜索路径3、配置文件/etc/ld.so.conf中指定的动态库搜索路径4、默认的动态库搜索路径/lib5、默认的动态库搜索路径%20/usr/lib
此处,我们使用了第2中方法来使用该动态库,先执行以下命令,设置LD_LIBRARY_PATH的值
[plain]%20view%20plain%20copy%20export LD_LIBRARY_PATH=. 之后,使用一下命令即可[plain]%20view%20plain%20copy%20./main新闻热点
疑难解答