在C語(yǔ)言中調(diào)用C++做的動(dòng)態(tài)鏈接庫(kù)
今天在做東西的時(shí)候遇到一個(gè)問(wèn)題,就是如何在C語(yǔ)言中調(diào)用C++做的動(dòng)態(tài)鏈接庫(kù)so文件
如果你有一個(gè)c++做的動(dòng)態(tài)鏈接庫(kù).so文件,而你只有一些相關(guān)類的聲明, 那么你如何用c調(diào)用呢,別著急,本文通過(guò)一個(gè)小小的例子,讓你能夠很爽的搞定.
鏈接庫(kù)頭文件:
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
這時(shí)候生成libmy.so文件,將其拷貝到系統(tǒng)庫(kù)里面:/usr/lib/
進(jìn)行二次封裝:
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
這時(shí)候生成第二個(gè).so文件,此時(shí)庫(kù)從一個(gè)類變成了一個(gè)c的接口.
拷貝到/usr/lib
下面開(kāi)始調(diào)用:
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
運(yùn)行Z$./myapp
10 $
相關(guān)文章
tc編譯的dos程序和vc編譯的win32控制臺(tái)程序的異同
tc編譯的dos程序和vc編譯的win32控制臺(tái)程序的異同...2007-08-08
C++ xxx_cast實(shí)現(xiàn)轉(zhuǎn)換代碼實(shí)例解析
這篇文章主要介紹了C++xxx_cast轉(zhuǎn)換代碼實(shí)例解析,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下2020-07-07
C語(yǔ)言實(shí)現(xiàn)套接字操作的示例代碼
在C語(yǔ)言中,套接字(Socket)是一種進(jìn)行網(wǎng)絡(luò)通信的接口,這篇文章就來(lái)和大家介紹一下C語(yǔ)言中是如何進(jìn)行套接字操作的,需要的可以參考一下2023-06-06
詳解C++二叉搜索樹(shù)的原理及實(shí)現(xiàn)
二叉搜索樹(shù)又稱二叉排序樹(shù),二叉搜索樹(shù)是一種二叉樹(shù),其中每個(gè)節(jié)點(diǎn)的值大于其左子樹(shù)中的任何節(jié)點(diǎn),并且小于其右子樹(shù)中的任何節(jié)點(diǎn),本文小編就給大家講講C++二叉搜索樹(shù)的操作及實(shí)現(xiàn),感興趣的同學(xué)跟著小編一起來(lái)看看吧2023-08-08
C語(yǔ)言實(shí)現(xiàn)的統(tǒng)計(jì)素?cái)?shù)并求和代碼分享
這篇文章主要介紹了C語(yǔ)言實(shí)現(xiàn)的統(tǒng)計(jì)素?cái)?shù)并求和代碼分享,來(lái)自PAT平臺(tái)(浙江大學(xué)計(jì)算機(jī)程序設(shè)計(jì)能力考試系統(tǒng))的一個(gè)題目,需要的朋友可以參考下2014-08-08

