欢迎您访问我爱IT技术网,今天小编为你分享的电脑教程是服务器系列之:【动态库调用静态库示例讲解】,下面是详细的分享!
动态库调用静态库示例讲解
生成动态库: 需要的目标文件得用-fPIC选项生成.
而静态库所需的目标文件可以不用-fPIC选项.
例:
代码如下:
/////// static.h
void static_print();
///////static.cpp
#include
#include "static.h"
void static_print() {
std::cout<<"This is static_print function"< } ////// shared.h void shared_print(); ////// shared.cpp #include #include "shared.h" #include "static.h" void shared_print() { std::cout<<"This is shared_print function"; static_print(); } ////////test.cpp #include "share.h" 方法一: 静态库的.o文件也用-fPIC生成. 生成动态库时把静态库加入. 生成应用程序时只加载动态库 代码如下: 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生成. 生成动态库时不加表态库. 生成应用程序时加载动态库和静态库. 代码如下: 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文件中. 个人觉得第一种方法更好, 因为动态库应该看成一个可以独立运行的程序. 以上就是关于动态库调用静态库示例讲解的服务器维护教程分享,更多电脑教程请移步到>>电脑教程频道。
int main()
{
shared_print();
return 0;
}
g++ -c -fPIC static.cpp // 生成static.o
g++ -c static.cpp // 生成static.o
- 评论列表(网友评论仅供网友表达个人看法,并不表明本站同意其观点或证实其描述)
-
