最近在对windows的代码进行移植过程中,发现编译后的动态库与java进行调用过程中出现无法加载或者未定义依赖库函数名的问题,就进行简单的测试:
1.文件目录
add文件夹:
//cpp
#include "add.h"
int add(int a,int b)
{
return a+b;
}
//h
extern int add(int a,int b);
dec文件夹:
// cpp
#include "dec.h"
int dec(int a,int b){return a-b;}
//h
extern int dec(int a,int b);
tes文件夹:
//cpp
#include "tes.h"
int func()
{
cout<<add(10,20)<<endl;
cout<<dec(25,2)<<endl;
return 1;
}
//h
#include <iostream>
#include "../add/add.h"
#include "../dec/dec.h"
using namespace std;
extern int func();
2.编译动态库
编译目标.o文件
g++ -fPIC add.cpp -c
g++ -fPIC dec.cpp -c
g++ -fPIC tes.cpp -c
此处添加-fpic的原因是:(-fPIC用于生成动态库),否则后面编译过程中就会报错,如下:
接下来把add dec tes 编译动态库,其中tes依赖add dec两个动态库文件
g++ -shared -fPIC tes/*.o -o libtes.so -I./add/ -I./dec/ -I./tes/ -L. -ldec -ladd -Wl,-rpath ./
此处添加-Wl,-rpath :告诉程序,在运行的时候如果找不到动态库,就去对应的路径查找(这里我给的当前路径)
或者更改 /etc/ld.so.conf 文件 添加当前的绝对路径 再 进行ldconfig 更新
注意事项:一定要使用命令ldd ***.so 查看一下是否成功链接库 ,否则后面调用会出问题
如下:
类型的错误如下:
根据错误去查看对应的动态库是否出现问题或者没有链接上。
链接不上就把命令多重复几次,检查错误,整体上都能成功的。
3.调用库
main.cpp
编译可执行程序
在这里就不用链接底层依赖库,只需要依赖当前的就行。
出现这种错误就是找不到对应的动态库:
可以通过设置 /etc/ld.so.conf 文件 或者 -Wl,-rpath 或者把so文件放在/usr/lib下。
基本上的问题就是linux基础有点差,遇到很多问题都需要长时间的去研究和解决,得清楚基本原理。