C++类的动态加载

利用继承关系,定义抽象类,只有纯虚函数构成的接口,然后具体的模块实现放在子类中。

通过extern "C" 解决C++名字修饰问题。得到子类指针。

然后所有函数的名字就遵循了统一约定。

涉及三个c相关的文件和一个makefile

 

main.cpp 为主程序负责调用so中的类的方法

Module.h 为模块通用接口

module1.cpp 为具体的某个模块的具体实现

Makefile描述编译

 

main.cpp

#include <iostream>
#include <stdio.h>
#include <stdlib.h>
#include "Module.h"
#include <dlfcn.h>

using namespace std;

int main(int argc,char *argv[])
{
    Module *mp;
    Module *mp1;
    void   *dp;

    typedef Module* (*fun)(void);
    
    fun pp;
    
    dp=dlopen("/mnt/c/Users/reed/Desktop/cppdll/libmodule1.so",RTLD_LAZY);
    
    if (dp==NULL)
    {
        fprintf(stderr,"Error: so load error\n");
        fprintf(stderr,"       %s\n",dlerror());
        exit(0);
    }
    pp=(fun)dlsym(dp,"generate");
    
    if (pp==NULL)
    {
        fprintf(stderr,"Error: symbol error\n");
        fprintf(stderr,"       %s\n",dlerror());
        exit(0);
    }
    
    mp=pp();
    mp1=pp();

    mp->run();
    mp1->run();
}

Module.h

#include <iostream>

class Module
{
public:
    virtual void  run()=0;
};

module1.cpp

#include <stdio.h>
#include <stdlib.h>
#include "Module.h"

class module1: public Module
{
public:
    void run()
    {
        printf("I am module1\n");
    }
};

extern "C" {
    Module *generate()
    {
        return new module1();
    }
};

Makefile

all:main so

main:main.cpp so
    g++ $< -o $@ -O2 -rdynamic  -ldl
so:module1.cpp
    g++ $< -shared -Wl,-soname,libmodule1.so -o libmodule1.so -O2 -fPIC

 

转载于:https://www.cnblogs.com/reedlau/p/5983094.html

  • 0
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值