Visual C#插件构架实战补遗

2016-02-19 17:07 27 1 收藏

清醒时做事,糊涂时读书,大怒时睡觉,无聊时关注图老师为大家准备的精彩内容。下面为大家推荐Visual C#插件构架实战补遗,无聊中的都看过来。

【 tulaoshi.com - 编程语言 】

  在软件开发的过程中,设计的过程往往比写代码的过程要难得多。因此,通常除了软件测试之外,耗时最多的也就是系统建模了。一个好的软件系统应当具有较高的稳定性(可靠性)、易操作性以及可扩展性支持,尤其是可扩展性。我认为,良好的可扩展性支持是一个软件团队在开发中变被动为主动的必要条件。对于一个应用,我们希望在用户增加需求时,我们能够用最少的时间、最少的人力来解决问题。当别人在用户快速增长的需求中忙得不可开交时(用户总是不能在第一次需求分析时将需求完完整整的告诉你),而你,你的团队只需要作一点工作就可以让贪得无厌的用户得到满足,从而提高了效率,让团队有更多的的时间来创造,而不是去做无谓的修改。

  很遗憾的是,在《C#插件构架实战》一文中,我并未考虑到这一点。当然,对于一个十八岁的没有也不可能有团队工作经验的年轻人来说,这样的失误(失误就是失败老师如是说)是可以原谅的(自我开脱之辞)。不过,我决定对这个插件系统进行重构。

  考虑到系统的复杂性,这次我准备使用UML(大上个月才开始学的,画得不好,见笑了)。

  1. 着手分析

  对于网友 jan 的指教,我大概明了,但人的思维差别太大,我不敢保证我的理解是完全符合 jan 的意思的。但是,我仍然会根据自己对可扩展性的理解构建一个应用程序框架模型。

(本文来源于图老师网站,更多请访问http://www.tulaoshi.com/bianchengyuyan/)

  直入正题。我现在假设我属于一个软件团队(就暂且叫她 AbstractSoft 吧),并任系统分析师。任何事物都有它规范的一面,我们希望我们的团队出品的部署在同一平台的所有应用都有相同的框架,相同的部署形式。这样便可以形成独有的团队特色,并在竞争中以效率取胜。因为我们不需要为每一套应用设计不同的框架这可以节约不少时间!

  这样我需要把程序实现与用户界面分开到不同的框架中。我的意思是:

  如此一来,在 Application Frame Level 的核心库中存在的是抽象接口以及一些泛化的细节。这些内容在第一次安装团队产品时就已经部署在用户的机器上了。它不会自动销毁,直到用户提交把它从本地移除的请求。GUI Level 提供了团队产品泛化后的统一的界面组件(比如:属性编辑器、数据库操作界面等可重用组件)。特化的产品(Speciallized Application)通过实现 Application Frame Level 中的某些接口实现可扩展性,通过使用 GUI Level 中的的类来实现用户界面。

  以下是一个简单的静态图(接口和类的成员将在下面详细阐述):

  2. IConnectableObject

  

public interface IConnectable { // application 为插件所属的主框架对象。若为null则表示插件本身就是主框架 ConnectionResult Connect( object application ); ExtendibleVersionInfo VersionInfo { get; } void OnDestory(); void OnLoad(); void Run();}public enum ConnectionResult { Connection_Success , Connection_Failed}public class ExtendibleVersionInfo { private ExtendibleVersionInfo() {} public ExtendibleVersionInfo( string name , string version , string copyright ) { // Omitted } public ExtendibleVersionInfo(string name,int version1,int version2,int version3,string copyright) { // Omitted } public int PrimaryVersion { get { return _Version1; } } public int SecondaryVersion { get { return _Version2; } } public int BuildVersion { get { return _Version3; } } public string Name { get { return _Name; } } public string VersionString { get { // Omitted } } public string Copyright { get { return _Copyright; } } private string _Name; private int _Version1 = 1; private int _Version2 = 0; private int _Version3 = 0; private string _Copyright; public static ExtendibleVersionInfo Empty = new ExtendibleVersionInfo();}

(本文来源于图老师网站,更多请访问http://www.tulaoshi.com/bianchengyuyan/)

  所有可连接的对象必须实现这个接口。这是所有 Application Frame Level 中类的鼻祖。

  3. IExtendible

  

public interface IExtendible { IConnectable GetLatestVersion(); IConnectable QuerySpecifiedVersion( ExtendibleVersionInfo version ); ExtendibleVersionInfo[] EnumerateVersions();}

  4. 使用类工厂创建应用程序和插件的最新版本

  我们的主程序以及插件会设计成 internal class 。程序只输出一个工厂类,用户界面通过调用 IExtendible 接口的 GetLatestVersion() 方法获得这些用来完成实际任务的对象的实例,并把它们显示出来。或者,也可以枚举所有的版本,让用户来挑选所需要版本。

  5. 可扩展性

  不得不承认,这样的方式可扩展性仍不是很强。程序需要升级时同时需要修改提供给用户的工厂类(虽然接口不变)。为了实现更好的可扩展性,可以把简单工厂模式转换为工厂方法模式。

来源:http://www.tulaoshi.com/n/20160219/1614267.html

延伸阅读
作为软件设计和开发人员大都有过使用DLL(动态连接库)的经历,DLL的产生使得我们的应用程序在可维护性、代码的重复使用等方面都有了很大的提高。以前用的DLL一般都是用Visual C++、Delphi或者VB等编程语言来编写的,这种DLL的编写和使用,我们大都已经比较习惯了。作为新一代的程序开发语言--Visual C#,到底是如何编写和使用DLL的呢!本...
程序的活动是通过语句(statement)来表达的。C#支持几种不同的语句,许多语句是以嵌入语句的形式定义的。 块(block)允许在只能使用单个语句的上下文中编写多个语句。块由一个括在大括号{}内的语句列表组成。 声明语句(declaration statement)用于声明局部变量和常量。 表达式语句(expression statement)用于运算表达...
前一篇《Visual C#.Net网络程序开发之Socket》中说到:支持Http、Tcp和Udp的类组成了TCP/IP三层模型(请求响应层、应用协议层、传输层)的中间层-应用协议层,该层的类比位于最底层的Socket类提供了更高层次的抽象,它们封装 TCP 和 UDP 套接字的创建,不需要处理连接的细节,这使得我们在编写套接字级别的协议时,可以更多地尝试使用 TCPCli...
前段时间因为项目需要,做了个用来对数组排序的类,顺便把以前学过的几种排序算法用C#实现一下。用C#的一些机制来诠释了一下算法的是实现。在阅读本之前,需要一些对C#的有些基本的了解,了解方法参数中out ,ref的作用,掌握面向对象的一些基本思想。 1. 插入排序 1.1. 基本思想: 每次将一个待排序的数据元素,插入到前面...
推荐: Visual C# 轻松入门全攻略 匿名方法基础 匿名方法是C#2.0的一个新的语言特性。本文的主要内容是提供给读者关于匿名方法的内部实现和工作方式的一个更好的理解。本文无意于成为匿名方法的完全语言特性参考。 匿名方法允许我们定义委托对象可以接受的代码块。这个功能省去我们创建委托时想要传递给一个...

经验教程

392

收藏

63
微博分享 QQ分享 QQ空间 手机页面 收藏网站 回到头部