老翅寒暑

一个老鸟的自白
随笔 - 74, 文章 - 0, 评论 - 654, 引用 - 17
数据加载中……

应用程序框架设计之前言

要做一个应用程序框架的念头Bigtall在几年前就有了,因为在工作中发觉很多方面非常的不顺手,几乎每一个环节都存在这样或者那样的问题:

  • 公司不同项目组做的设计是完全不同的风格,而且设计做不细,导致项目计划越来越流于形式
  • 各层代码凌乱,从后台的java或者c#到前台的html,天马行空,随心所欲
  • 数据库结构和文档不匹配,要不是莫名其妙的多、少字段,要不就是些莫名其妙的名字

如果深入到设计方面,就会发现虽然做过很多的项目,但是几乎没有可以参考的成功案例,所有的设计哪怕是同类型项目,也几乎要重头开始;编码方面就更加麻烦了,我最深刻的印象就是从业以来我编制了无数的字符串处理函数,有c/c++版本的,有C#版本,有java版本的,还有delphi和早已忘记的vb,当然,更少不了时下流行的js了(这还是好的呢)。一旦到了项目规模较大的时候,我们甚至会在代码流程中迷路,不知道调用从哪里来,不知道逻辑要往哪里跳。

这么多的问题,是广大的处于CMM 1级的软件企业共同存在的问题,当然也会出现在那些CMM2345实际还是CMM1的软件企业中。加入管理手段(比如真正去实施CMM规范)可以解决大部分的问题,准确地说是可以解决几乎所有的管理问题并缓解大部分的技术问题,但是解决不了所有的问题。

以前bigtall在的公司曾经出现过这种论调“技术是不重要的,市场和管理才是最重要的”,最后公司走入了低谷,好不容易聚集的人才也散了。别人的教训就是自己的经验,bigtall后来进行深刻的反思,认为这里有一个“度”的问题,我们先看两个极端“只有市场和管理但是没有技术”“只有技术没有市场和管理”的后果,一个是“守不住”,一个是“推不了”。其实两者是相辅相成的,技术可以把市场的门槛推高,市场和管理可以让技术更顺利地发展。所以一个公司没有“最好”的技术,只有“最适合”的技术。一个公司的技术目标应该也只应该是“不断降低公司的成本”。

最明显的就是项目系统设计的重用问题,无论你是CMM多少级,如果没有一个统一的软件架构,重用就会打折扣甚至根本就无法重用。就像南方人北方人沟通要用普通话,今人和古人沟通就必须用相同的文字(顺便鄙视并可怜一下朝鲜、韩国和越南)一样,前后的项目要能够沟通交流,他们就需要一个相同的结构。所以“程序框架”就是公司项目之间的“普通话”,也是项目内部的“润滑剂”。

这里要明确一下“程序框架(Framework)”和“软件架构(Architecture)”之间的区别,简单地说,程序框架是一个可以实际应用的代码集合,而软件架构可以看作是一种抽象的设计。另外,两者的关注面也不一样,程序框架热衷于解决实际运行过程中的问题,甚至会提供工具包或者辅助模块(比如权限系统、日志系统等),而软件架构则集中精力在各个部分(模块、组件等)之间的关系。两者其实是关于同一个事情的不同层次的东西。

我们可以来看一下如果存在程序框架会让文章开头的几个问题解决多少:

  1. 如果有程序框架,因为项目的WBS几乎是一致的,所以上一个项目的项目计划可以直接拿过来使用,而且经过几个项目之后,这个项目计划的模板会越来越细,越来越实用。
  2. 设计过程中,除了需求之外,概要设计、详细设计的重用性会很高。
  3. 因为结构一致,代码混乱性会降低到可以接受的程度,而且可以重用上一个项目的大部分代码。而且逻辑清晰,使得代码相对较小,不容易在代码中迷失。因为代码逻辑简单有序,所以测试起来会很容易。
  4. 降低管理成本,除了项目计划之外,测试计划,QA计划等等都可以重用,如果用CMM规范,项目评审的速度和质量都会有提高。

要做一个应用程序框架并不是一件容易的事情,一是这方面发展很快,而且水平相对较高,如果没有独到的解决方案,可能自己的框架一出来就过时了。二是应用程序框架涉及的方面较多,考虑清楚并不是一件容易的事情。三则是开发一个应用程序框架需要耗费大量的时间,也就是意味着公司需要花费(你的工资×开发时间+其他)这么多的金钱。

对于小公司来说,除非有着清醒的认识,否则开发自己的应用程序框架可能是自寻死路。bigtall建议小公司如果.net开发,则直接用Petshop4的框架,如果java开发,则直接使用appfuse进行开发,如果想要一个新的语言,则直接用Ruby On Rails开发吧。对于php没有建议,不太熟。

现在如果要开发一个应用程序框架,至少需要满足如下的几个条件:

  • 分层(废话)
  • 易于测试
  • 易于扩展,并跟现有的其他系统进行无缝整合。一般要具有AOP、IOC、DI能力。
  • 易于部署
  • 具有权限,用户管理能力
  • 有组织架构、工作流、规则引擎支持
  • 有页面流转,状态管理能力
  • MOF或者MDA能力
  • SOA能力
  • 界面技术的抽象能力(如WebForm,HTML,Ajax,Xml,Rich Web等)

bigtall的应用程序框架设计系列文章准备从简单开始,一步一步记录并呈现给大家bigtall开发框架的整个过程。文章列表如下:

  1. 多层应用之间的数据传递: 分层和层间数据传递(上)、分层和层间数据传递(下)
    多层架构已经成为了标准,但是数据在穿越各个层次的时候,它的形态有什么变化和规律呢?
  2. 界面层的分析和抽象
    界面层承载了应用程序所有的可视部分,究竟里边还有多少我们需要关注但是却忽略了的事实?
  3. MOF/MDA的支持和程序的设计规范
    如果人在根本上是不可靠的,那么就尽可能不用人去做。但是到达这一步,我们还需要告诉机器一些什么东西?
  4. 工具!我的工具!
    bigtall设计的小工具
  5. 待续

posted on 2007-12-06 12:56 老翅寒暑 阅读(3557) 评论(36)  编辑 收藏 所属分类: 软件工程

评论

#1楼    回复  引用  查看    

博主于我心有戚戚耶 :D

不过不同意博主说的“对于小公司来说,除非有着清醒的认识,否则开发自己的应用程序框架可能是自寻死路。”

应用程序框架是日积月累,不断重构而成的,它跟架构师的技术深度和广度、以及长久的经验累积有关。

博主继续,我将持续关注 :D
2007-12-06 13:05 | 碧落      

#2楼    回复  引用  查看    

可以卖钱
2007-12-06 13:10 | beyondjay      

#3楼    回复  引用    

好东西,期待。
2007-12-06 13:13 | 支持你 [未注册用户]

#4楼    回复  引用  查看    

支持
我也在想类似的事情
2007-12-06 13:29 | Anders Cui      

#5楼    回复  引用  查看    

支持一下.
2007-12-06 13:46 | 沙加      

#6楼    回复  引用  查看    

写的不错 值得一看
2007-12-06 13:48 | 秀才      

#7楼    回复  引用  查看    

重构与重用
2007-12-06 13:50 | Enzo      

#8楼    回复  引用  查看    

期待,并学习中。。。。
以前园子里也有人气势汹汹地说要开发什么框架,可后来又没动静了。。。让人失望!
2007-12-06 14:00 | 阿牛 - 专注OOP      

#9楼    回复  引用  查看    

等待下文。坚持坚持。
2007-12-06 14:08 | 伍迷      

#10楼    回复  引用    

写的很好,我第一次这么说人!
2007-12-06 14:32 | ph [未注册用户]

#11楼    回复  引用    

好想法 真是好东西 我认为:应用程序框架是日积月累,不断重构而成的,它跟架构师的技术深度和广度、以及长久的经验累积有关.
2007-12-06 14:52 | 赵艳坤 [未注册用户]

#12楼    回复  引用  查看    

一直在关注这方面,楼主写的不错,期待你的文章。。。
2007-12-06 15:02 | Bright Zhang      

#13楼    回复  引用  查看    

关注
2007-12-06 15:21 | 大豆男生      

#14楼    回复  引用    

--引用--------------------------------------------------
碧落: 博主于我心有戚戚耶 :D

不过不同意博主说的“对于小公司来说,除非有着清醒的认识,否则开发自己的应用程序框架可能是自寻死路。”

应用程序框架是日积月累,不断重构而成的,它跟架构师的技术深度和广度、以及长久的经验累积有关。

博主继续,我将持续关注 :D
--------------------------------------------------------
good
2007-12-06 15:43 | renyanbinnet [未注册用户]

#15楼    回复  引用    

--引用--------------------------------------------------
大豆男生: 关注
--------------------------------------------------------
good
2007-12-06 15:45 | renyanbinnet [未注册用户]

#16楼    回复  引用    

--引用--------------------------------------------------
renyanbinnet: --引用--------------------------------------------------
大豆男生: 关注
--------------------------------------------------------
good
--------------------------------------------------------
good
2007-12-06 15:47 | renyanbinnet [未注册用户]

#17楼    回复  引用    

@renyanbinnet
@大豆男生
good,good
2007-12-06 15:49 | renyanbinnet [未注册用户]

#18楼    回复  引用    

@renyanbinnet
@伍迷
good,good,good
2007-12-06 15:50 | renyanbinnet [未注册用户]

#19楼    回复  引用    

good
2007-12-06 15:54 | renyanbinnet [未注册用户]

#20楼    回复  引用    

good,good
2007-12-06 16:25 | dated [未注册用户]

#21楼    回复  引用    

good,goodgood,good
2007-12-06 16:25 | dated [未注册用户]

#22楼    回复  引用  查看    

LZ的东西很实在,这正是我最关注的问题,期待LZ的续篇
2007-12-06 16:59 | Terry Sun      

#23楼    回复  引用  查看    

框架包括的特性太多
1. 没有这么多精力投入
2. 从你的环境状况来看,一次想要跳跃的太远
2007-12-06 17:32 | RicCC      

#24楼    回复  引用  查看    

个人感觉部分功能可以分开单独设计开发.实际应用时再做整合.譬如:权限,工作流.再者有的地方可以利用下企业库.我们研发事业部(CMM5)提供的面向WEB系统的框架.实际应用很不错.
2007-12-06 17:56 | 预备役中尉      

#25楼    回复  引用  查看    

Mark一下,明天来看
2007-12-06 19:15 | 周银辉      

#26楼    回复  引用    

http://www.springframework.cn/htm_data/14/0711/312.html

这个网站里面就有一个现成的程序框架,我做了一个CodeSmith模版!已经可以成功自动生成所有代码,加入配置可以使用。做一个基础点的程序,也就需要1个钟以内。如果需要复杂点的设置,那就在原来的基础上进行修改。

FastSpring.NET 是一个集成了Spring.NET & NHibernate & Ajax 的WEB开发框架。

熟悉的朋友应该知道这两个开源项目的吧?我写CodeSmith模版的时候不断地测试,最近已经是基本上把模版完成了。感觉真的很好。
2007-12-06 20:09 | kfarvid [未注册用户]

#27楼    回复  引用  查看    

请问能分享吗?


--引用--------------------------------------------------
kfarvid:

这个网站里面就有一个现成的程序框架,我做了一个CodeSmith模版!已经可以成功自动生成所有代码,加入配置可以使用。... 感觉真的很好。
--------------------------------------------------------
2007-12-07 02:08 | jun      

#28楼 [楼主]   回复  引用  查看    

to kfarvid:
你的做法跟我的想法竟然是很相似的路子,呵呵!
to RicCC:
跳得太远是因为我们站在了巨人的肩上,所以不要害怕!
2007-12-07 15:35 | 老翅寒暑      

#29楼    回复  引用    

似乎是个搞软件的人都会慢慢想到要去重构,要去做框架,不过大家觉悟的时间不一样
2007-12-10 12:49 | zhchang [未注册用户]

#30楼    回复  引用  查看    

弱弱的问:“如果有程序框架,因为项目的WBS几乎是一致的”,这里的"WBS"是什么意思啊 ?
2007-12-12 12:22 | temptation      

#31楼    回复  引用    

写得很好,很有深度,重用和架构有时挺难分清楚的.继续关注.
建议啊,可以谈谈基于struts框架的一些新技术吗.
2007-12-17 10:07 | 飞扬2007 [未注册用户]

#32楼    回复  引用    

博主,你好,

订阅你的文章很久了。最近也在思考同类的问题。希望你的这个系列的文章继续写下去,不要开了个好头就没有了下文哦
2008-04-05 23:28 | martos [未注册用户]

#33楼    回复  引用    

期待下文
2008-06-01 22:44 | kangaroo [未注册用户]

标题  
姓名  
主页
Email (只有博主才能看到) 
验证码 *  看不清,换一张 [登录][注册]
内容(请不要发表任何与政治相关的内容)  
  登录  使用高级评论  新用户注册  返回页首  恢复上次提交      
该文被作者在 2007-12-10 18:30 编辑过