共享库(动态库)的.so 文件类似于.dll 文件。共享函数库在可执行程序启动的时候加载,所有程序重新运行时都可自动加载共享函数库中的函数。
实验代码如下:
/***test_a.cpp***/
#include <stdio.h>
#include "test.h"
void TestA()
{
printf("TestA func\n");
}
/***test.h***/
#ifndef _TEST_H_
#define _TEST_H_
void TestA();
void TestB();
#endif
/***test_b.cpp***/
#include <stdio.h>
#include "test.h"
void TestB()
{
printf("TestB func\n");
}
/***test.cpp***/
#include"test.h"
int main()
{
TestA();
TestB();
return 0;
}
生成so文件的命令:
g++ test_a.cpp test_b.cpp -fPIC -shared -o libtest.so
-fPIC:表示编译为位置独立的代码,不用此选项的话编译后的代码是位置相关的所以动态载入时是通过代码拷贝的方式来满足不同进程的需要,而不能达到真正代码段共享的目的。
-shared 该选项指定生成动态连接库(让连接器生成T类型的导出符号表,有时候也生成弱连接W类型的导出符号),不用该标志外部程序无法连接。相当于一个可执行文件
注意事项:生成的.so必须以 lib开始。生成的 .so也是可执行文件,可以用ldd –v libtest.so 查看共享库的依赖关系
采用动态库编译命令:
g++ test.cpp -o test -L. -ltest
-L. :表示要连接的库在当前目录中
-ltest:编译器查找动态连接库时有隐含的命名规则,即在给出的名字前面加上lib,后面加上.so来确定库的名称
执行:
export LD_LIBRARY_PATH=./
ldd test
./test
说明:如果你写好了自己的动态链接库,需要在其它程序里调用,则需要让这些程序能找到这些动态链接库,如果设置不对就会错误,因此上面在运行程序前加了一句export LD_LIBRARY_PATH=./ 。也可以把它加入到系统环境变量中。