插件架构学习体会(一) -- 宿主程序说:插件你得听我的

简介: 看了一段时间的#develop,首先接触到的就是程序的插件架构。园子里也有许多不错的资料可以学习。随时把自己的认识写下来和大家交流,无疑会有很大帮助。闲话就不说了,进入正题。     说到插件架构,首先要有一个整体印象,到底什么才是插件架构?这个问题的答案很好找,找个插件架构的程序看看就可以了,比如VS,MyIE,再比如千千静听。
   看了一段时间的#develop,首先接触到的就是程序的插件架构。园子里也有许多不错的资料可以学习。随时把自己的认识写下来和大家交流,无疑会有很大帮助。闲话就不说了,进入正题。
     说到插件架构,首先要有一个整体印象,到底什么才是插件架构?这个问题的答案很好找,找个插件架构的程序看看就可以了,比如VSMyIE,再比如千千静听。我们可以开发不同功能的插件,加载到宿主程序上,功能就能发挥作用。宿主程序呢,完全不知道我们到底什么样的功能,怎么实现的。这里呢,我想从我们平常写程序时引用一些类库说起。我们经常会把一些功能封装到一个dll中,然后在其他项目中引用,引用时,直接调用其中的方法就ok了。Dll是编译过的,方法名是我们自己知道的,无论是自己写的dll,还是引用别人的,总之,我们一定知道我们调用的什么方法。试想一下,如果我们加一个约定,约定了这个dll中的方法名,那这个时候,这个dll的客户程序是不是不用管是什么dll,只要调用约定的方法就可以了?那再想一下,这个dll非得引用吗?动态加载行不行?当然行,加载之后,去调用约定的方法,完全可以。到这里,我们发现,其实只要一个约定,客户程序完全不需要去在意它的服务者是什么样的状态,exe也好dll也好,只要能提供契约里的方法就ok了,它只关心有没有这么一个方法可以调用。至此,发现这不就是最最简单的一个插件架构的样子吗?
   
接下来,赶紧动手写个例子试一下:
    首先,定义一个契约,这里采用了接口,那最好再来一个实现该接口的抽象类,如下
     public  interface  IPlugIn
    
{
        
//往控制台上打印东西,这里可以写任何你想要的契约行为
        void PrintToConsole();
    }

    接下来,写宿主程序,宿主程序肯定要先加载实现了IPlugIn的插件,然后调用其约定的方法。在.Net里无非就是反射一下就ok了,看代码:
  static  void  Main( string [] args)
        
{
            List
<IPlugIn> PlugIns = LoadPlugIn();
            
if (PlugIns != null)
            
{
                
foreach (IPlugIn p in PlugIns)
                
{
                    p.PrintToConsole();
                }

            }

            Console.ReadLine();      

        }

        
/// <summary>
        
/// 加载插件
        
/// </summary>
        
/// <returns>返回可用插件的列表</returns>

         private  static  List < IPlugIn >  LoadPlugIn()
        
{
            List
<IPlugIn> Plugs = new List<IPlugIn>();
            Assembly a 
= null;
            
try
            
{
               a 
= Assembly.LoadFile(Console.ReadLine());
            }

            
catch 
            
{
                Console.WriteLine(
"File not found!");
                
return null;
            }

            System.Type[] types 
= a.GetTypes();
            
foreach (System.Type type in types)
            
{
                
//校验加载的dll是否实现了契约,当然此处也可以用Attribute来实现
                if (type.GetInterface("IPlugIn"!= null)
                
{
                    Plugs.Add((IPlugIn)Activator.CreateInstance(type));
                }

            }

            
return Plugs;
        }

    }
    下一步,该完成插件了,实现那个接口而已嘛,简单
         // 实现了contract里约定的方法,控制台上输出"Hello world"字符串
         public  void  PrintToConsole()
        
{
            Console.WriteLine(
"Hello world!");
        }
    测试一下,为了方便,我把插件dll copy到G盘根目录下(可以少打几个字母哦),运行宿主程序,输入该dll路径,看到了我们预期的hello world
    
    代码地址: http://files.cnblogs.com/Pcant/SimplePlug-in.rar    (待续)
    园子里相关资源推荐:
    http://www.cnblogs.com/guanjinke/archive/2007/03/14/675109.html
    http://www.cnblogs.com/wayfarer/articles/28537.html
目录
相关文章
|
1月前
|
Dubbo Java 应用服务中间件
Apache ShenYu 架构学习指南
Apache ShenYu 是一款高性能、插件化的微服务API网关,基于Spring WebFlux + Reactor 构建,支持多协议、动态配置与实时数据同步。本指南以通俗类比和实战路径,带你深入理解其架构设计、核心流程与源码实现,助力快速掌握并参与贡献。
249 12
|
1月前
|
Kubernetes Go API
Kubeflow-Model-Registry-架构学习指南
Kubeflow Model Registry 是一个用于管理机器学习模型元数据的基础设施,采用 Go、Python、React 和 Kubernetes 技术栈,支持模型版本、注册与存储追踪。本指南系统解析其分层架构、核心流程与代码结构,提供从环境搭建到贡献代码的完整学习路径,助力开发者深入掌握模型管理实践。
124 0
|
1月前
|
Kubernetes Go 调度
Kubeflow-Trainer-架构学习指南
本指南系统解析Kubeflow Trainer架构,涵盖核心设计、目录结构与代码逻辑,结合学习路径与实战建议,助你掌握这一Kubernetes原生机器学习训练平台的原理与应用。
396 139
|
1月前
|
Kubernetes API 开发工具
Kubeflow-Pipelines-架构学习指南
本指南带你深入 Kubeflow Pipelines 架构,从零掌握 ML 工作流编排。涵盖核心组件、代码结构、开发调试及贡献流程,结合实战练习与学习路径,助你由使用者进阶为贡献者。
344 139
|
1月前
|
Kubernetes Cloud Native Go
Kubeflow-KServe-架构学习指南
KServe是基于Kubernetes的生产级AI推理平台,支持多框架模型部署与管理。本指南从架构解析、代码结构到实战部署,系统讲解其核心组件如InferenceService、控制器模式及与Knative、Istio集成原理,并提供学习路径与贡献指南,助你快速掌握云原生AI服务技术。
403 139
|
4月前
|
人工智能 自然语言处理 开发工具
统一多模态 Transformer 架构在跨模态表示学习中的应用与优化
本文介绍统一多模态 Transformer(UMT)在跨模态表示学习中的应用与优化,涵盖模型架构、实现细节与实验效果,探讨其在图文检索、图像生成等任务中的卓越性能。
统一多模态 Transformer 架构在跨模态表示学习中的应用与优化
|
1月前
|
并行计算 PyTorch 算法框架/工具
vLLM 架构学习指南
本指南深入解析vLLM高性能推理引擎架构,涵盖核心创新PagedAttention与连续批处理技术,结合代码结构、学习路径与实践建议,系统指导用户从入门到贡献源码的全过程。
476 2
vLLM 架构学习指南