在C說話中挪用C++做的靜態鏈接庫。本站提示廣大學習愛好者:(在C說話中挪用C++做的靜態鏈接庫)文章只能為提供參考,不一定能成為您想要的結果。以下是在C說話中挪用C++做的靜態鏈接庫正文
明天在做器械的時刻碰到一個成績,就是若何在C說話中挪用C++做的靜態鏈接庫so文件
假如你有一個c++做的靜態鏈接庫.so文件,而你只要一些相干類的聲明, 那末你若何用c挪用呢,別焦急,本文經由過程一個小小的例子,讓你可以或許很爽的弄定.
鏈接庫頭文件:
head.h
class A { public: A(); virtual ~A(); int gt(); int pt(); private: int s; };
firstso.cpp
#include <iostream> #include "head.h" A::A(){} A::~A(){} int A::gt() { s=10; } int A::pt() { std::cout<<s<<std::endl; }
編譯敕令以下:
g++ -shared -o libmy.so firstso.cpp
這時候候生成libmy.so文件,將其拷貝到體系庫外面:/usr/lib/
停止二次封裝:
secso.cpp
#include <iostream> #include "head.h" extern "C" { int f(); int f() { A a; a.gt(); a.pt(); return 0; } }
編譯敕令:
gcc -shared -o sec.so secso.cpp -L. -lmy
這時候候生成第二個.so文件,此時庫從一個類釀成了一個c的接口.
拷貝到/usr/lib
上面開端挪用:
test.c
#include "stdio.h" #include "dlfcn.h" #define SOFILE "sec.so" int (*f)(); int main() { void *dp; dp=dlopen(SOFILE,RTLD_LAZY); f=dlsym(dp,"f"); f(); return 0; }
編譯敕令以下:
gcc -rdynamic -s -o myapp test.c
運轉Z$./myapp
10 $