软件架构(C#)
2024-07-21 02:18:55
供稿:网友
学过软件工程的朋友应该都知道,合理的软件架构(software architecture)对后期的维护、新功能的添加是极为有利的。我对研究 windows 的架构非常有兴趣,自己也想动手实践一下。但是很遗憾,我没有什么大软件的代码可以拿来研究,说句实话,就算是有,可能我也没时间去钻研。
我只好拿我以前写的一个小软件来改造,这个软件最早的一些版本结构显得不太清晰(我已经写了20多个版本啦)。也许你会觉得这对一个小软件来说没有必要,但这只是一个试验性的东西,将来这个架构也可以用于更大一些的软件。要知道系统结构对大型软件来说非常之重要,一个合理的结构会节省很多的工作量。
先简单介绍一下我的改造对象吧。aoouchware(r) date convert 可以用于修改文件的创建时间、修改时间、访问时间,支持批量更改。可以对系统时间进行实时追踪。本软件基于microdoft.net技术编写,正常的使用需要首先安装 microsoft.net framework 1.0 版或更高的版本。
从下面的图中可以看到在 sp2 版中外壳层和管理层是分开的,但是最初的 release 版上面两层是和在一起的。所以从 sp1 版我就开始了对它的改造工作,要把一开始就定义为一个整体的两个层次完全的分开并不容易,所以我分了两步进行。sp1 版算是一个半改造的东西吧,上面两层并未完全的分离,只是把各个模块中的 文字信息提取到了一个文件 notify.dll 中,这样的架构还不算完美。现在我的这个版本已经基本上把我头脑中的架构实现了,尽管对内存的优化还要放在下个版本中(.net 程序的内存占用实在是太大了)。
下面简单谈一下我的研究成果吧。其实说是研究成果,只不过是把我头脑中的一些想法变成现实罢了。
我的思路说明:我的目标就是要把它分成3个层次,也就是外壳层(shell layer)、管理层(manage layer)和内核层(kernel layer)。外壳层主要包括 notify.dll 和 ushell.dll,这两个是用户直接接触到的,他们的任何更改对软件功能都没有直接影响。管理主要由主程序来实现,主程序中没有任何可以进行实质性工作的代码,只是提供了对接口的管理功能,目的是把上下两层有效的衔接起来。这样即使要更新下层的代码或接口,都不会牵涉到用户层,也就是说,软件更新包的大小不会很大。核心层包括两部分,一个是环境监测(environment),包括 envirchk.dll、verrep.dll,这两个模块主要实现的是文件版本管理和环境变量管理,如果用户在更新时留下了不属于当前版本的文件,程序是不会运行的。还有一部分当然就是实现软件功能的执行(execution)模块了,包括 fileevt.dll、timechkr.dll,这个我就不多介绍了。
各个模块的具体作用:
notify.dll 用来存储用户界面上的文字信息,也可以被其他模块调用以发出提示信息。这也为多语言程序的开发提供了便利。
ushell.dll 这是界面部分,主程序的界面是从这个文件中继承的。这样一来便实现了换肤功能。
datecov.dll 这就是主程序,实现了对上下两层的衔接和管理。
envirchk.dll 这个模块用作检测环境变量,和版本管理。不合理的变量是不能被引用的,同样错误的版本将导致程序不能运行。
verrep.dll 用来返回各个模块现在正确的版本号。
fileevt.dll 用来调用打开文件(夹)对话框,以及执行对文件的更改。
timechkr.dll 可以返回当前的系统时间,以及实现对用户输入时间的标准检测,这样可以避免很多不必要的错误。
date convert + sp2 下载地址: http://free.efile.com.cn/aoouch/aoouchware/dcsp2/dcsetup_chs.exe
pluspack for sp2 下载地址: http://free.efile.com.cn/aoouch/aoouchware/dcsp2/dcpsetup_chs.exe
关于软件的下载:我发布的那个安装包是绿色的,如果你还不放心可以用 winrar 来解开。英文版的安装包我就不提供了,如果想用英文版的朋友可以下载 pluspack 来实现。