当前位置: 首页 > article >正文

[C++技能提升]插件模式

在 C++ 中,插件(Plugin)是一种设计模式,允许程序在运行时动态加载和使用外部模块或库。这种模式可以增强应用程序的灵活性和可扩展性,使得开发者可以在不修改主程序代码的情况下扩展其功能。

插件的实现步骤

以下是一个简单的 C++ 插件系统的实现步骤:

  1. 定义插件接口:创建一个抽象基类,定义插件的公共接口。
  2. 实现具体插件:实现插件接口的具体类。
  3. 动态加载插件:使用动态链接库(DLL)或共享对象(SO)来加载插件。
  4. 使用插件:主程序通过插件接口与具体插件进行交互。

example:

1. 定义插件接口
// plugin_interface.h
#ifndef PLUGIN_INTERFACE_H
#define PLUGIN_INTERFACE_H

class PluginInterface {
public:
    virtual void execute() = 0; // 纯虚函数
    virtual ~PluginInterface() = default; // 虚析构函数
};

#endif // PLUGIN_INTERFACE_H
2. 实现具体插件
// plugin_a.cpp
#include <iostream>
#include "plugin_interface.h"

class PluginA : public PluginInterface {
public:
    void execute() override {
        std::cout << "Executing Plugin A" << std::endl;
    }
};

// 导出插件创建函数
extern "C" PluginInterface* create() {
    return new PluginA();
}

// 导出插件销毁函数
extern "C" void destroy(PluginInterface* plugin) {
    delete plugin;
}
// plugin_b.cpp
#include <iostream>
#include "plugin_interface.h"

class PluginB : public PluginInterface {
public:
    void execute() override {
        std::cout << "Executing Plugin B" << std::endl;
    }
};

// 导出插件创建函数
extern "C" PluginInterface* create() {
    return new PluginB();
}

// 导出插件销毁函数
extern "C" void destroy(PluginInterface* plugin) {
    delete plugin;
}
3. 主程序
// main.cpp
#include <iostream>
#include <dlfcn.h> // Linux 下的动态链接库头文件
#include "plugin_interface.h"

void loadAndExecutePlugin(const std::string& pluginPath) {
    // 加载插件
    void* handle = dlopen(pluginPath.c_str(), RTLD_LAZY);
    if (!handle) {
        std::cerr << "Cannot load plugin: " << dlerror() << std::endl;
        return;
    }

    // 加载创建插件的函数
    typedef PluginInterface* (*CreatePlugin)();
    CreatePlugin createPlugin = (CreatePlugin)dlsym(handle, "create");
    if (!createPlugin) {
        std::cerr << "Cannot load create function: " << dlerror() << std::endl;
        dlclose(handle);
        return;
    }

    // 创建插件实例并执行
    PluginInterface* plugin = createPlugin();
    plugin->execute();

    // 加载销毁插件的函数
    typedef void (*DestroyPlugin)(PluginInterface*);
    DestroyPlugin destroyPlugin = (DestroyPlugin)dlsym(handle, "destroy");
    if (destroyPlugin) {
        destroyPlugin(plugin);
    }

    // 卸载插件
    dlclose(handle);
}

int main() {
    loadAndExecutePlugin("./plugin_a.so"); // 加载插件 A
    loadAndExecutePlugin("./plugin_b.so"); // 加载插件 B
    return 0;
}


http://www.kler.cn/a/519742.html

相关文章:

  • 力扣算法题——11.盛最多水的容器
  • 如何移植ftp服务器到arm板子?
  • 二十三种设计模式-享元模式
  • C语言复习
  • ThinkPhp伪静态设置后,访问静态资源也提示找不到Controller
  • 【优选算法】9----长度最小的子数组
  • 低代码系统-氚云、简道云表单控件对比
  • Typesrcipt泛型约束详细解读
  • 实现宿主机(Windows 10 Docker Desktop)和Linux容器之间的数据挂载的三种方法
  • 【力扣每日一题】LeetCode 2412: 完成所有交易的初始最少钱数
  • Oracle之开窗函数使用
  • Vue编程式路由跳转多次执行报错
  • go入门Windows环境搭建
  • doris: CSV导入数据
  • (一)HTTP协议 :请求与响应
  • Android Toast在指定的Display里面显示
  • TLF35584 基本介绍
  • JAVASE入门十脚-红黑树,比较器,泛型
  • 校园商铺管理系统设计与实现(代码+数据库+LW)
  • 计算机网络 (62)移动通信的展望
  • ChatGPT的本质是什么?
  • 一文详解Filter类源码和应用
  • Linux下php8安装phpredis扩展的方法
  • 【更正版】梯级水光互补系统最大化可消纳电量期望短期优化调度模型
  • Yocto项目 - 解读CROss PlatformS (CROPS)
  • 飞牛NAS安装过程中的docker源问题