生成动态库: 需要的目标文件得用-fPIC选项生成.
而静态库所需的目标文件可以不用-fPIC选项.
例:
代码如下:
/////// static.h
void static_print();
///////static.cpp
#include <iostream>
#include "static.h"
void static_print() {
std::cout<<"This is static_print function"<<std::endl;
}
////// shared.h
void shared_print();
////// shared.cpp
#include <iostream>
#include "shared.h"
#include "static.h"
void shared_print() {
std::cout<<"This is shared_print function";
static_print();
}
////////test.cpp
#include "share.h"
int main()
{
shared_print();
return 0;
}
方法一:
静态库的.o文件也用-fPIC生成. 生成动态库时把静态库加入.
生成应用程序时只加载动态库
代码如下:
g++ -c -fPIC static.cpp // 生成static.o
ar -r libstatic.a static.o // 生成静态库libstatic.a
g++ -c -fPIC shared.cpp // 生成shared.o
g++ -shared shared.o -lstatic -o libshared.so // 生成动态库libshared.so 注: -shared是g++的选项,与shared.o无关. -lstatic选项把libstatic.a的函数加入动态库中.
g++ test.cpp -lshared -o test.exe // link libshared.so 到test.exe中.
方法二:
静态库的.o文件不用-fPIC生成. 生成动态库时不加表态库.
生成应用程序时加载动态库和静态库.
代码如下:
g++ -c static.cpp // 生成static.o
ar -r libstatic.a static.o // 生成静态库libstatic.a
g++ -c -fPIC shared.cpp // 生成shared.o
g++ -shared shared.o -o libshared.so // 生成动态库libshared.so 注: -shared是g++的选项,与shared.o无关. 这时如果加-lstatic. error:relocation R_X86_64_32 against `a local symbol' can not be used when making a shared object; recompile with -fPIC
g++ test.cpp -lshared -lstatic -o test.exe // link libshared.so 到test.exe中.
两种方法的不同之处在于static_print的实际代码一个在.so中.一个在最后test.exe文件中. 个人觉得第一种方法更好, 因为动态库应该看成一个可以独立运行的程序.
您可能感兴趣的文章:Linux动态库函数的详解Linux静态库与动态库实例详解详解dll动态库的开发与调用及文件的读写小程序android studio2.3如何编译动态库的过程详解Linux下g++编译与使用静态库和动态库的方法Linux环境g++编译GDAL动态库操作方法解决Linux程序编译链接动态库版本的相关问题xcode 详解创建静态库和动态库的方法浅谈Linux C语言动态库及静态库c++实现加载so动态库中的资源linux 程序、动态库、静态库内部添加版本号和编译时间详解从源码编译Android系统的Java类库和JNI动态库的方法C#调用非托管动态库中的函数方法Visual Studio中根据系统区分引用64位、32位DLL动态库文件的配置方法linux生成(加载)动态库静态库和加载示例方法深入探讨Linux静态库与动态库的详解(一看就懂)分析Windows和Linux动态库在动态库和静态库中使用模板(dynamic libraries ,static libraries)