- 浏览: 2059109 次
- 性别:
- 来自: 厦门
文章分类
- 全部博客 (1409)
- asp/asp.net学习 (241)
- oracle (10)
- delphi (295)
- java (27)
- pb (1)
- 每日点滴 (49)
- 学习方法 (40)
- 思想方面 (104)
- C语言 (5)
- C++ (1)
- 代码重构经验 (5)
- 软件工程 (3)
- 数据库 (99)
- 英语学习 (3)
- mysql (1)
- 该关注的网站或者网页 (42)
- 总结 (7)
- 要去做的事情 (33)
- 算法 (1)
- 网络方面 (29)
- 随感 (96)
- 操作系统 (36)
- UML (12)
- 常用工具的使用 (55)
- 脚本 (7)
- 汇编 (62)
- 数据结构 (2)
- 财务 (38)
- 语文作文 (16)
- 法律 (1)
- 股票 (88)
最新评论
-
devwang_com:
可以,学习了~~
列出文件夹下所有文件夹的树形结构--Dos命令 tree的使用 -
hvang1988:
不管用啊 frxrprt1.PreviewForm.Pare ...
fastReport预览时嵌入到别的窗体 -
00915132:
我也有这个疑问,非常 感 谢
left join加上where条件的困惑 --SQL优化 -
zhuyoulong:
学习了,高效读书
软件架构师要读的书 -
nTalgar:
非常感谢分享!
Application.ProcessMessages用法:
李维的borland传奇
第十三章 软件科技的发展和Borland的未来
不都是整理和抽丝剥茧吗?
我在从事信息工作的生涯中使用过数种不同的程序语言、数据库、组件模型以及
Framework。面对许多新的技术不断地出现,开发人员似乎陷入了永远学不完新东西的
梦魇。不过,如果开发人员仔细回味许多技术的本质,却会发现这些技术其实只是把
我们已经了解的东西再以更细致化的方式加以运用,关键在于开发人员是否注意到了
这些本质和趋势而已。
例如,目前在C++中流行得火热的Template、Policy-Based template,在Java、Object
Pascal和C#中当红的接口程序设计,以及各种组件模型和Web Service中的服务接口
等,如果我们仔细地咀嚼,会发现许多的东西正是发挥程序员原本就拥有的整理和抽
丝剥茧精神,再加以发挥的东西。这怎么说呢?让我们以数个例子来说明读者就容易
了解了。
首先让我们想想为什么会出现数据库这类的产品?很简单,因为由于数据愈来愈多,
数据种类也愈来愈繁杂,因此造成了我们需要一种软件产品能够整理这些数据让它们
更容易的被我们处理和使用,因此才有了数据库的想法和产品。
在每一个程序员学习撰写程序代码时,也会发现随着撰写的程序代码愈来愈多,许多
的程序代码不断重复出现和被使用,因此很自然的程序员开始使用例程(routine)/子
程序(subroutine)或是过程(procedure)、函数(function)等机制帮助我们进行程序
代码整理和抽丝剥茧的工作。
这些数据和程序代码整理的工作几乎是每一个程序员的求生本能,只是有的程序员只
做基本的整理工作,而更聪明的开发人员则对于整理的工作有不同的看法,进而促使
了许多延伸软件技术的出现,也开始对软件开发产生了重大的影响。例如,对于原本
杂乱的程序代码以数据和程序代码分离的看法而逐渐产生了面向对象的技术,以分离
例程/子程序和数据类型为看法的应用则产生了类似C/C++中的template技术,而以函
数面对服务的看法,认为开发人员应该面向服务的开发模式则造成了接口程序设计
(Interface Programming)的应用热潮。虽然现在这些从程序代码延伸出的技术都独领
风骚,在软件开发界中产生了重大的影响和开发模式的改变,但是,如果我们追根究
底来观察,这些技术不都是从对程序代码和数据的分析、整理和抽丝剥茧之后,以更
精致的方式来处理和开发软件吗?
因此,本着相同的想法和精神,聪明的开发人员开始脱离单一程序语言的架构而进入
了开发出可重复使用的软件组件模型,让不同的程序语言都能够在统一的组件模型中
达成团队开发的功效。这个更聪明的整理和抽丝剥茧的想法造就了CORBA、COM/COM+
和EJB等组件模型的驱动力。
除了脱离程序语言之外思考的开发人员外,另外有一些开发人员则再次回头检视本身
和他人的程序代码,并且努力搜寻优良和成功程序代码的基因,因此发现了这些优良
和成功的程序代码似乎都有着类似的模式和架构,再经过进一步的分析之后终于产生
了Design Pattern,这成为目前最重要的软件开发模式和技巧之一。在这之后,这些
聪明的开发人员了解到如果能够成功运用Design Pattern,并且把程序设计转变成以
服务为目标的方式,将更能够简化、标准化和结合Design Pattern的运用,并且隐藏
复杂的实现技巧,这就进而产生了Service Interface Programming的观念和技巧。
由此可见,只要开发人员能够发挥细心整理和抽丝剥茧的能力,那么即使无法创造出
伟大的新软件工程或是软件技术,但是仍然能够帮助我们增加生产力和软件品质。因
此,对于开发人员来说重要的不是无止境地学习层出不穷的各种新技术,而是到底有
没有了解这些技术之后代表的观念、思想,以及学习最重要的对于软件开发整理和抽
丝剥茧的能力。在我的工作生涯中,一直认为技术终究是会被大多数的人学会的,但
是在辛辛苦苦地努力这么多年后,到底我们的思想、眼光和抽丝剥茧的能力是否有所
精进呢?如果没有,那么我们永远就像被蒙着眼睛,只能尾随着他人告诉的技术前进,
永远找不到自己的方向。
现在,再让我们以一个C++的例子来证明只要开发人员能够看透程序语言和技术背后
代表的真实意义,那么即使是在已经被众人熟知的技术中,仍然能够创造出新的技术
和含义。在Andrei Alexandrescu先生所著的"Modem C++Design"一书中,我们再次看
到了聪明的开发人员对于程序语言的了解和对于程序代码撰写整理以及抽丝剥茧的惊
人能力。Andrei的想法不算复杂,但是却巧妙地运用了对于C++ template深刻的了解
而创造出了自己的精彩之作。其实,全书呈现的思维之妙,让读者可以从一开始的小
范例就看出如何运用已经广为人知的技巧之后呈现出的不同风貌。
例如,Andrei想法是以Policy-Based想法为主,以各种不同的准则来提供服务函数,
那么通过C++ template的能力,让开发人员能够根据自己的需求来选择需要的Policy
和数据类型,结合于C++的template,可以捉供开发人员前所未有的自由度,并且开
启了以往函数库开发人员无法想象的挥洒空间。例如,下面的程序代码中提供了三个
不同的类别,这三个类别都可以建立指定类别T的对象实例(Object Instance),但是,
这三个类别各自使用了不同的方式来建立T的对象实例。在这里提供了建立T类别的对
象实例的准则Create()方法,但是却允许开发人员自由地根据自己的需求选择要使用
那一种方式来建立对象实例。
由于上面的三个类别提供了相同的Policy(其实,从Service Programming的角度来看,
可以说它们都提供了相同的服务),因此,开发人员可以再自行定义一个consumer类别,
并且结合C++的template功能,让这三个服务类别成为客制化数据类型,再通过template
的能力,自由地被开发人员选择使用。例如在下面的程序代码中,WidgetManager
类别通过template功能可以在编译时期动态决定使用那一个Policy类别作为父代类别,
而自动拥有建立T类别的对象实例的能力。
最后,我们可以再次使用template能力在编译时期由开发人员代入欲建立的T类别的
实体类别定义,通过template功能结合Policy服务和各种不同的数据类型。例如,下
面的程序代码即指定了使用OpNewCreator这个Policy服务类别,以传统的new操作数
来建立Widget类别的对象实例,并且定义成新的客制化类型MywidgetMgr:
typedef WidgetManager<OpNewCreator<Widget>>MywidgetMgr;
在这个范例中,我们看到了Andrei真正了解了程序语言的机制,并且经过他的思考和
抽丝剥茧之后,开创出了以Policy为主的template class library。Andrei的这番思
考的确为C++语言开创了新的应用和视野,这正是发挥开发人员聪颖的整理和抽丝剥
茧能力的另外一个好典范。
不过,C++的template功能却只局限于C++程序语言本身,这是因为template是C++语
言本身的特性,只有C++编译器提供了强劲支持。所以,C++的template无法在程序语
言之外和其他的程序语言合作提供类似组件模型的能力,因为其他的程序语言并不了
解template,也不支持template,这也是为什么Microsoft会以COM来提供不同程序语
言之间的整合,EJB则更单纯地只限定使用Java的原因。
其实在上面讨论的C++ template中,仍然可以通过混合编译时期和执行时期的功能来
提供C++在组件模型和其他程序语言或是技术结合的能力,同时又能够使用C++本身强
劲的语言机制。例如,我们可以在外部使用XML作为组态文件,以指定我们想要使用
的Creator以及想要建立的对象。例如下面的XML内容即指明了和前面相同的Creator:
OpNewCreator,以及要建立的对象:Widget:
而C++可输出一个纯粹的服务接口,类似COM的接口以便和其他组件模型或是程序语言
整合:
最后,在CPPCreator的实体衍生类别中可以通过分析XML组态文件的内容来决定建立
何种的Manager:
上述的机制可以让C/C++语言提升至组件模型和其他的技术整合的层面,又能够仍然
使用本身强大的template、Policy-Based template或是template函数库。当然,这
里我并不是以讨论C/C++程序语言的技巧为主,不过,上面的程序代码仍然可以进一
步使用dynamic dispatch来改善,成为品质更好的程序代码。
其实,这些想法和实现机制仍然是在使用整理和抽丝剥茧程序代码的方式来解决问题,
只是以更细致的想法重新给予程序语言或是工具新的意义并且运用在日常的开发生活
之中,有时候只要脑筋稍为转个弯就能够看到新的应用。
现在,除了在程序语言层面运用各种整理和抽丝剥茧的技术来增进我们开发的速度和
品质之外,许多人已经开始运用相同的想法在建立企业应用系统了。例如,现在许多
人已经了解Design Pattern除了在程序语言方面有实质的帮助之外,在企业应用系统
的设计方面更有极大的应用价值。而且许多人已经开始整合这方面的Design Pattern,
例如Martin Fowler最新著的"Patterns Of Enterprise Application Architecture
"一书中便分析和整理了他观察和使用Design Pattern在设计和发展企业应用系统的
心得。在这本书中,Martin Fowler也清楚地说明了他只是发挥了整理和抽丝剥茧的
原则提供给开发企业应用系统的开发人员参考,许多的Design Pattern并不是他发明
的。可见,现在许多的开发人员只是更精炼地观察和整理多年的开发经验,以萃取出
更佳的Coding和开发的技巧以及开发惯例。
而Design Pattern运用在企业应用系统中的功用是能够帮助开发人员更了解整个系统
的架构,并且更容易掌握如何分门别类企业应用系统不同层次之间如何的切割和分发,
能够营造出体质更为健全的复杂企业应用系统。
目前,这股重新整理和抽丝剥茧的风气也已经蔓延到各种信息开发领域,从程序语言、
组件模型一直到大型应用系统的设计和开发。我认为,下一步将继续进入整个开发流
程的领域之中。当软件厂商提供了完整的开发流程工具之后,就开始会有人研究如何
在开发流程中再度应用Design Pattern等技术。
因此在未来,开发人员必须了解Patterns,并且在开发的过程中时时注意软件开发的
趋势和使用惯例,不断吸收更多的技巧,以更精致的思想和方式来开发软件,如此一
来才能够脱颖而出,在软件开发的生涯中出人头地。
Web Service Works
SOAP和Web Service从去年开始快速兴起,并开始占据信息整合应用的市场。虽然许
多人提出对于SOAP和Web Service执行效率和安全性的质疑,但是,SOAP和Web Service
的穿透力、整合力却无庸置疑是极具吸引力的。因此,目前Web Service的各种规格
除了蓬勃发展之外,Web Service的应用也的确开始出现在我们的四周。不过,Web
Service到底应用在哪些方面呢?SOAP和Web Service目前在信息业界使用的情形如何?
相信这些都是许多人关心的问题,也是许多人想要知道的答案。
最近,我被邀请到一家信息机构交流信息技术的心得。主持人告诉我他们现在拥有一
个分布区域极为广大的信息系统。每一个区域使用的硬件、操作系统、数据库和开发
工具都不同。而且,目前这些系统之间并没有专线连接在一起。现在他们想要整合这
些系统,而且希望能够在机构中心向不同的区域查询货物数据并且在机构中心整合查
询到的信息。
这位主持人询问我有没有什么方法可以完成这个信息架构。在详细地讨论之后,我了
解到机构中心从各个区域查询的信息都是属于小量数据的查询。由于在每一个不同的
区域都有自己的数据库,因此可以通过每一个区域的数据库服务器从大量的数据中撷
取查询数据,再把查询到的结果传回机构中心进行简单的整合工作。
对于这个信息架构,我想最简单的方法就是在每一个区域的服务器上实现一个CORBA
服务器,再由CORBA服务器对外提供查询接口。由于CORBA拥有跨平台、数据库和开发
语言中立的特点,因此非常适合使用来作为原有专属系统提供对外的标准服务接口。
有了CORBA服务器作为服务接口之后,我们可以继续把CORBA服务转换为标准的Web
Service,再由机构中心使用SOAP,即可轻易地使用标准机制穿透并且整合原本的异
质系统。
使用Web Service的原因是由于在这个应用中只会有少量的资料查询,因此Web Service
绝对可以胜任,而Web Service提供的穿透力和整合力是其他技术难以相比的。对于
安全的需求,可以使用HTTPS加上CORBA的安全服务即可提供一定的安全可靠性。
原本看起来困难的事情一下子就被Web Service和CORBA联手解决了。这正是一个非常
好的Web Service应用范例。
那么在2002年,Web Service在信息业界应用的情形到底是如何呢?到底有没有信息
系统在使用SOAP和Web Service技术呢?其实,我们从各种开发工具都支持Web Service
的应用来看,一定是有人已经在使用Web Service了,否则没有必要几乎所有的开发
工具都争先恐后地加入对于SOAP和Web Service的支持。
下图是2002年信息界对于使用Web Service的最后调查结果,从数字中我们可以看到,
没有使用Web Service的比率是43.2%,但是超过50%的调查显示Web Service已经
或多或少的被应用在信息系统之中了。而这些统计数据也代表了Web Service被实际
应用的证明。
另外一份对于Web Service应用的调查结果如下页所显示。我们可以看到在2003年中
Web Service将有更大的使用比率,可见Web Service的应用将会快速地提升。
如果我们把两份统计结果以趋势图同时呈现的话,会发现Web Service应用的成长比
率几乎不会输给一般的开发工具或是程序语言的成长比率。
在2003年Web Service除了将愈来愈普及之外,新的Web Service规格也将慢慢完善并
且开始被软件厂商实现。除此之外,也开始有信息厂商对Web Service的缺点加以改
善推出变形的解决方案。不过千变万变,不变的是在现在信息多元化的时代正显示了
我们的确需要Web Service代表的穿透力和整合力。
许多人当初说Web Service是不实际的技术,从目前的各种迹象和统计数字来看这些
人似乎是错了。Web Service的简单化不代表无用,其缓慢也不代表不可用。我们只
需要在适当的地方使用适当的技术,Web Service就是一个很好的例子。毕竟当初Don
Box在定义SOAP时最原始的想法本就是"简单(Simple)",不是吗?
发表评论
-
你有压力吗? ---《当下的力量》
2011-10-19 13:56 10672011-10-19 摘自:《当下的力量》 ... -
时间管理
2010-09-06 18:30 800摘自:http://www.iteye.c ... -
327国债-- 管金生
2010-08-27 10:41 723管金生被判入狱7年 摘自:http://fin ... -
普通百姓的致富之路--段绍译
2010-08-23 16:24 868吾阅:不要吃掉种子,留下种子; 鸡生蛋,蛋生鸡;要 ... -
(转)我的个人知识管理工具软件
2010-08-04 16:42 1485吾阅:推荐用PKM2,做的不错,善用佳软推荐,免费,绿 ... -
城市与农村---当缺水缺电时
2010-08-03 20:52 865吾阅:城市与农村--- ... -
五年前的眼光,决定了你今天的结果!
2010-07-29 13:19 9462010-7-29 吾阅:现在是2010年,五 ... -
图难于其易,为大于其细。天下难事,必作于易;天下大事,必作于细--《道德经》
2010-07-29 11:55 3485吾阅:做事先挑简单 ... -
捷径--就是多走弯路
2010-07-25 22:14 1160吾阅:多走弯路,即多尝试,多失败,然后总结出来,才知道什 ... -
时间管理习惯的培养
2010-07-23 22:29 1103吾阅:晚上给第二天作 ... -
天涯的第三广告模式很好
2010-07-21 18:22 1236吾阅:天涯的第三广告模式很好; 而这种“天涯式” ... -
(转)激发自己的思考
2010-07-20 14:51 828----------------------- ... -
当你疲倦时,当你想放弃时,看看这个吧!---人生没有捷径
2010-07-16 13:45 962吾阅:年轻的时候,想轻松,老了就要痛苦了; ... -
思考两步骤
2010-07-16 09:55 709思考两步骤: 1. 对方说这些话的目的是什 ... -
导购要学会察言观色
2010-07-13 23:39 926吾阅:察言观色 判断人的眼光; 摘自:《给年轻工 ... -
《宗吾臆谈》--李宗吾
2010-07-03 18:41 1148《宗吾臆谈》--李宗吾 办事二妙法:锯箭法 ... -
一味顺从的人没有好果子吃
2010-07-02 08:17 1161吾阅:跟俺很像 ... -
社会——最好的大学
2010-06-28 15:20 833吾阅:在社会这个大学里,没有了老师的监督,没有了其它人的 ... -
《看穿他心中的鬼--洞悉语言魔术》--多湖辉(日)
2010-06-26 18:01 11882010-6-26 《看穿他心中的鬼--洞悉语言 ... -
年轻的普遍特征——急于摆脱现状 ----笑来
2010-06-24 15:17 839吾阅: 生活的本质是什么呢?无非 ...
相关推荐
在线教育行业近年来迅速发展,尤其在K-12阶段,形成了多种教学模式和经济模型。中金公司的报告深入探讨了在线K-12教培经济模型,并对未来的行业趋势进行了预测。以下是对报告中涉及的知识点的详细阐述: 1. 在线...
就业报告系列之一:抽丝剥茧,就业压力并不大-0226-光大证券-19页.pdf
在React的世界里,"抽丝剥茧的学前端之React篇"是一段深入学习和实践React框架的心得体验。这个项目旨在系统性地讲解React的基础概念、核心特性以及实际项目搭建的过程,帮助开发者逐步理解并掌握React技术栈。 ...
《抽丝剥茧App混合开发进阶课》是一门针对移动应用开发的高级教程,旨在帮助开发者深入理解并掌握混合开发技术。这门课程通过视频形式呈现,为学习者提供了丰富的视听体验,使抽象的编程概念更加生动易懂。课程不仅...
Spring是一个开放源代码的设计层面框架,他解决的是业务逻辑层和其他各层的松耦合问题,因此它将面向接口的编程思想贯穿整个系统应用。Spring是于2003 年兴起的一个轻量级的Java 开发框架,由Rod Johnson创建。简单...
在线K-12(Kindergarten through 12th grade)教育是近年来教育行业的一大热点,尤其是在全球数字化进程的推动下,其经济模型逐渐成为研究...随着科技的进步和社会需求的变化,在线教育的经济模型也将不断演进和完善。
教育行业新机遇系列之四:抽丝剥茧,探寻民办学校成长真谛-180306.pdf
"在线教育系列之二:抽丝剥茧,详解在线K~12教培经济模型" 本报告对在线教育系列的第二部分,深入探讨在线K~12教培经济模型。我们认为,随着在线教育营销获客规范度提升,未来一段时间在线教育机构的线上投放获客将...
上述知识点是从提供的【部分内容】中抽丝剥茧得到的信息,尽管信息不完整和存在一些OCR扫描错误,但大体上符合计算机组成原理的教学大纲和考核内容。如果需要更详尽、准确的知识点整理,则需要具体的试题内容和完整...
【行业分析】报告聚焦于权益基金中的行业主题基金,旨在帮助投资者更准确地识别和选择具有潜在超额收益的基金产品。报告指出,超额收益的产生与行业特性紧密相关。 首先,报告强调行业内个股收益分化大的行业更容易...
- 培养对数据的敏感度,能够从复杂图表中抽丝剥茧,找到关键信息。 - 熟练运用函数和数形结合的思想。 - 具备良好的逻辑推理能力,能从图表中推断出问题的答案。 - 精准表达,确保答案符合题目要求。 通过对这类...
在解读这份华西证券于2021年发布的调味品行业深度报告时,我们可以从中提炼出以下几点关于调味品行业的发展现状...该深度报告提供了调味品行业内部变化和行业展望的详尽分析,对投资者和业内人士均具有很高的参考价值。
本文标题为“中泰证券_0118_量化投资策略报告:抽丝剥茧,透视行业和风格,重构A股量化分析框架”,从字面上可提炼出几个关键知识点:量化投资策略、行业与风格分析、A股市场、重构分析框架。报告详细分析了如何通过...
本书以 uC/OS-III 官方源码为蓝本, 抽丝剥茧, 不断迭代,教你怎么从 0 开始把uC/OS-III 写出来。 书中涉及到的数据类型,变量名称、函数名称,文件名称,文件存放的位置都完全按照 uC/OS-III 官方的方式来实现,当...
通过这样的资料,你可以了解到如何从复杂的问题中抽丝剥茧,找出最优的解决方案。例如,可能会涉及二分查找、动态规划、回溯法等经典算法的应用。 学习LeetCode的解题过程,不仅是掌握算法,更是一种思维方式的训练...
混合式app开发只需要要求开发者会使用css和js前端代码就可以实现手机app应用的开发,而不需要再去学习安卓或苹果开发,降低了app开发的门槛。混合式开发做出的手机应用无论在性能还是易用性方面都很接近原生app应用...
ACM-ICPC(国际大学生程序设计竞赛,International Collegiate Programming Contest)是全球最具有影响力的大学生编程比赛之一,旨在提升学生的算法设计、问题解决和编程技能。SWERC(Southwest European Regional ...
4. **逻辑思维**:试题往往需要参赛者具备良好的逻辑推理能力和问题分析能力,能从复杂的问题中抽丝剥茧,找到解决问题的关键点。 5. **调试技巧**:在解答过程中,学会利用调试工具检查程序运行状态,定位并修复...
叶金荣-知数堂-抽丝剥茧之MySQL疑难杂症排查.pdf 德哥-阿里云-sharding单元化(based on postgres_fdw)最佳实践.pdf 余星-平安壹钱包-浅谈PostgreSQL 高可用架构.pdf 范孝剑-阿里云-PG优化器浅析.pdf 张广舟...