1、接口

using System;
using System.Collections.Generic;
using System.Linq;
using System.Text; namespace PlugDemo
{
public interface IPlugToText
{
string ProccessText(string text);
}
}

2、菜单属性Class

using System;
using System.Collections.Generic;
using System.Linq;
using System.Text; namespace PlugDemo
{
public class MenuNameAttribute:Attribute
{
private string _name; public string Name
{
get { return _name; }
set { _name = value; }
} public MenuNameAttribute(string name)
{
this._name = name;
} }
}

3、实现接口的实现类

using System;
using System.Collections.Generic;
using System.Linq;
using System.Text; namespace ComPlugDemo
{
[PlugDemo.MenuName("转小写")]
public class PlugToLower : PlugDemo.IPlugToText
{
#region IPlugToText 成员 public string ProccessText(string text)
{
return text.ToLower();
} #endregion
}
}
using System;
using System.Collections.Generic;
using System.Linq;
using System.Text; namespace ComPlugDemo
{
[PlugDemo.MenuName("转大写")]
public class PlugToUpper:PlugDemo.IPlugToText
{ #region IPlugToText 成员 public string ProccessText(string text)
{
return text.ToUpper();
} #endregion
}
}

4、反射机制:

using System;
using System.Collections.Generic;
using System.ComponentModel;
using System.Data;
using System.Drawing;
using System.Linq;
using System.Text;
using System.Windows.Forms;
using System.Reflection;
using System.IO;
using PlugDemo; namespace 插件Demo
{
public partial class Form1 : Form
{
public Form1()
{
InitializeComponent();
} private void Form1_Load(object sender, EventArgs e)
{
AddPlugMenu();
} void AddPlugMenu()
{
//1、加载正在运行的程序集的物理路径
Assembly ass = this.GetType().Assembly; string location = ass.Location; //2、获取 程序集所在文件夹,并转成 插件程序集文件夹的路径
string assDir = Path.GetDirectoryName(location); string plugDir = assDir + "\\plugs"; //3、扫描 产检文件夹里的 所有程序集文件
string [] dllPaths = Directory.GetFiles(plugDir,"*.dll"); //重点: 获取插件接口 类型对象 //4、遍历程序集文件路径,并加载程序家到内存中
Type iplugType = typeof(IPlugToText); foreach (string dllPath in dllPaths)
{
//4.1 、根据路径 加载程序集文件 到内存中
Assembly amy = Assembly.LoadFrom(dllPath); //4.2 、判断程序集中是否有插件类
//4.2.1、获取插件程序集里公有的类
Type[] types = amy.GetExportedTypes();
//4.2.2 循环遍历 插件程序集里的类型 ,判断是否实现记事本插件接口
foreach (Type t in types)
{
//判断 t 是否 实现了接口 IPlugToUpper
if (iplugType.IsAssignableFrom(t))
{
//重要,获取的MenuNameAttribute 特性对象,或将 内部的Name现在到菜单中
object[] atts = t.GetCustomAttributes(typeof(MenuNameAttribute),false);
MenuNameAttribute menuName = atts[] as MenuNameAttribute; //重要:根据插件类型,创建 插件类 对象
IPlugToText iplug = Activator.CreateInstance(t) as IPlugToText; ToolStripMenuItem item = new ToolStripMenuItem(menuName.Name); plugMenu.DropDownItems.Add(item); item.Click += new EventHandler(item_Click); item.Tag = iplug;
}
}
} } void item_Click(object sender, EventArgs e)
{
ToolStripMenuItem item = sender as ToolStripMenuItem; IPlugToText iplug = item.Tag as IPlugToText;
textBox1.Text = iplug.ProccessText(textBox1.Text);
}
}
}

C# 反射实例的更多相关文章

  1. ObjectTools反射实例

    ObjectTools反射实例 package com.shitou.deposit.chinapnr.utils; import org.apache.commons.logging.Log; im ...

  2. 类的反射实例(servlet的抽取)

    类的反射实例 具体以后我们写的时候不用写BaseServlet,因为各种框架都已经给我们写好了 所以,user对应的servlet的界面长这样:

  3. C#反射实例应用--------获取程序集信息和通过类名创建类实例

    AppDomain.CurrentDomain.GetAssemblies();获取程序集,但是获取的只是已经加载的dll,引用的获取不到. System.Reflection.Assembly.Ge ...

  4. PHP API反射实例

    *反射是操纵面向对象范型中元模型的API,其功能十分强大,可帮助我们构建复杂,可扩展的应用.其用途如:自动加载插件,自动生成文档,甚至可用来扩充PHP语言.php反射api由若干类组成,可帮助我们用来 ...

  5. java反射 实例

    首先介绍几个概念: 1.Java反射的概念 反射含义:可以获取正在运行的Java对象. 2.Java反射的功能 1)可以判断运行时对象所属的类 2)可以判断运行时对象所具有的成员变量和方法 3)通过反 ...

  6. c# 类的反射实例 (GetType().Invoke().GetMethod().CreateInstance())

    原文:http://www.cnblogs.com/chenwei19/archive/2009/02/04/1384034.html Class1和Form 窗体在同一个命名空间 using Sys ...

  7. C#反射实例(一) 利用反射使用类库

    在网上查找了不少的资料,可以说大同小异,概念性的东西网上一搜一堆,今天把反射的东西整理了一下,供大家使用,我保证我这里是最全面的东西,当然也是基础的东西,在学好了这一切的基础上,大家可以学习反射的具体 ...

  8. Java 反射实例

    实体类:Userpackage com.reflect.model; public class User{ private User(int id, String username, String p ...

  9. go反射实例

    需求分析: 如在rocketmq的网络通信中,所有通信数据包以如下形式传输: (注:rocketmq的java结构体,这里使用了go形式表示) type RemotingCommand struct ...

随机推荐

  1. 2016_NENU_CS_3

    贴一下比赛的代码,  其中 I 题代码源于final大神 ok_again http://acm.hust.edu.cn/vjudge/contest/127444#overview I /***** ...

  2. XML的基礎結構

    1.xml是什麼? xml,Extensible Markup Language,扩展性标识语言,後綴名為.xml. 2.xml有什麼功能? xml功能是傳輸和儲存數據,用於不同的應用和平台數據共享和 ...

  3. C从源码到运行发生了哪些事

    一个C/C++程序从源代码到可执行程序主要经历了四个阶段: ①预处理.包括展开宏.处理#include,#if,#ifdef等指令.删除注释.还有一些其他操作.相关命令:gcc -E或cpp ②编译. ...

  4. 洛谷 P1392 取数

    题面 在做这道题前,先要会他的弱化版(实际一模一样,只是愚蠢的洛谷评测级别差了一档(睿智如姬无夜)) ----------------------------------弱化版------------ ...

  5. multi_index_container 多索引容器

    multi_index_container是c++ boost库中的一个多索引的容器.因工作中用到了,特来测试试用. #include "stdafx.h" #include &q ...

  6. jenkins和sonar的几个问题

    错误1:有个pom文件内容错了,但是在jenkins上面编译的时候,控制台将这个错误信息给打出来了,maven的编译也打印了failed with error,但是jenkins的job并没有因此而停 ...

  7. 在finally块中使用try catch,并且catch的时候抛出异常的一个问题

    在finally中使用try/catch,并且catch的时候抛出异常 IDEA会提示警告 Reports throw statements inside of finally blocks. Whi ...

  8. 1.Zabbix报错信息:It probably means that the systems requires more physical memory.

    点击返回:自学Zabbix之路 1.Zabbix报错信息:It probably means that the systems requires more physical memory. 1.报错信 ...

  9. 自学Linux Shell7.2-linux文件权限

    点击返回 自学Linux命令行与Shell脚本之路 7.2-linux文件权限 在linux中每个文件有所有者.所在组.其它组的概念 所有者一般为文件的创建者,谁创建了该文件,就天然的成为该文件的所有 ...

  10. 学习Spring Boot:(二十五)使用 Redis 实现数据缓存

    前言 由于 Ehcache 存在于单个 java 程序的进程中,无法满足多个程序分布式的情况,需要将多个服务器的缓存集中起来进行管理,需要一个缓存的寄存器,这里使用的是 Redis. 正文 当应用程序 ...