学过软件工程的朋友应该都知道,合理的软件架构(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 来实现。