发信人: pilot (喜欢下雨的夜猫子), 信区: BorlandDev
标 题: 《Delphi高手突破》第一章——预览版
发信站: 哈工大紫丁香 (2002年01月22日12:06:33 星期二), 转信
标题 《Delphi高手突破》第一章——预览版
Nicrosoft(原作)
写在前面的话:目前,正在写一本面向delphi熟练程序员的书,主题是在delphi中使用
面向对象编程技术构建良好设计的程序。
此书还在写作过程中,我希望能让大家先对此书的主题以及语言风格能有一个预先的了
解。同时,能提出自己的意见。作为作者,我希望这本书能成为国内原创Delphi图书中
的经典之作,未必能成功,但我尽力。
由于以上原因,我不可能将整本书都贴出来(呵呵,那样就没人去买了),所以应该不
会有后续章节贴在这里(或许会有一些节选吧)了。
在此,我要感谢那些鼓励过我、提出过意见的朋友(在csdn的delphi论坛我贴过,得到
广泛的响应,谢谢大家了)。还要感谢一直支持、激励我的女友——Esan。我所能做的
,就是把书写好,回报大家,我知道,大家(包括我)等好书等的太辛苦了!
第1章 重新认识Delphi
简单性是这个世界上最难获得的东西:它是经验的最终界限,也是天才的最终努力目标
。——George Sand
您已经是一位熟练的Delphi程序员,可以运用Delphi快速地写出一个漂亮、实用的程序
;您热爱Delphi;她已经成了您工作、学习中不可或缺的一部分。我假设这些都为真,
那么您当初选择Delphi作为自己的首选开发工具一定有自己的理由或者原因。
至少,我自己是符合以上的所有假设的。现在,我所想和您分享的,正是我选择Delphi
的理由及原因,以及我对Delphi的认识。您可以把我看作一个拥护Delphi的狂热分子,
虽然那样会让我感到您把我看得太过肤浅,我并不承认,但是我不介意。因为,我真的
热爱她。
第一次接触的Delphi的版本是3.0,那时候只不过把它当作Visual Basic一样的RAD工具
来用而已。但是,随着时间的流逝,Delphi 3、Delphi 4、Delphi 5、Delphi 6以及Ky
lix,对Delphi的认识也越来越深。它是有着丰富内涵的工具,让人对她越了解,就越对
她迷恋,越感觉离不开她,虽然它也还只是工具。
Pascal是一种讲究程序美学的语言——毫无疑问,Pascal代码是最优美的代码——基于
Object Pascal(一种支持面向对象的Pascal语言)的Delphi让这种美达到了极至。
现在,你可以打开Delphi,选择“Help”-“About”菜单,出现About窗口后,按住Al
t键,同时顺序键入“team”,你看到了什么?是的,Delphi开发人员名单,让我们感谢
他们制造出如此的更象艺术品的开发工具吧!
1.1 开发工具“以人为本”论
经常可以在各个编程论坛上看到类似这样的问题:“VB还有没有前途?”;“Delphi是
不是要淘汰了?”;“MFC是不是要被.NET取代了?”……其实,这些问题在被提出的当
时,是没有人能给出答案的。因为一种技术、一个产品的前途,并不完全由其本身所能
左右,还与市场需求、出品公司的发展方向等因素有关。而我们所应该关注的,是否就
是这些问题的答案呢?我认为不是。
我们知道,世间万物由原子组成;千变万化的程序归根结底由顺序、循环、分支三种结
构构成;无论VC的MFC,还是Delphi的VCL,都是由面向对象技术构建的(暂且不论其面
向对象的程度)。当你拨开事物表面的表象后,你看到的,是相同的或近似的本质!而
掌握了本质之后,就会发现表象的表现形式是那么的理所当然。试想,当你能象侯捷(
《深入浅出MFC》的作者)那样把MFC剥得体无完肤,你还会担心MFC被某某框架所取代吗
?从这个角度来说,对于一名专业程序员,编程的理念是万变不离其宗的。发现问题、
分析问题、解决问题的过程是存在着某种模式的,当你掌握了这种模式后,不同的编程
语言,不同的开发环境对你来说,是有共通之处的。
我认为C++是每个专业程序员所必须掌握的。当然,并不是说单纯学习其语法(甚至可以
忽略一些语法的学习),而是通过C++学习面向对象的设计、编程方法。因为C++博大精
深,因为C++无所不及。在C++中,你可以学习到面向对象理论的全部,学习之后,你会
被C++所改造。因为在面向对象理论中存在的,但有所争议的特性(比如:多重继承)在
C++中都得到支持。你只有在掌握之后,才可能作出自己的选择(支持或反对)。在掌握
了面向对象的理论之后,无论C++、Object Pascal或是Java乃至C#,你会感觉到它们的
异曲同工之处。
那是否就是说开发工具(或许应该称为集成开发环境,不过下文还是按我的习惯,用开
发工具来称呼)之间除了支持的语言不同外,不存在其他差异了?当然也不是。开发工
具是帮助你实现你的理念的工具,也就是构建在基础理念上的上层建筑。开发工具对于
你所要实现的理念的支持程度以及对实现过程的简化程度,就是开发工具的体贴度了。
开发工具于程序员,犹如兵器于士兵,兵器不顺手,未战先败一半。
一直很喜欢诺基亚手机的广告词:科技以人为本!是的,“人”才是本,工具的使命是
辅助人更快、更容易地达到目的。因此,开发工具也应该以人为本!
作为一名程序员,作为开发工具的最直接的使用者,我希望我所使用的开发工具真正是
我的伙伴、助手,它能给我带来自由的感觉,让我自由地在代码的世界中驰骋,它能迁
就我、适应我,而不是相反,给我套上枷锁!
如今在Windows平台上,有许许多多的开发工具可以选择:Visual C++、Visual Basic、
Delphi、C++ Builder、JBuilder……它们基于不同的编程语言、忠于不同的公司的产品
理念,从这个角度来说,它们之间的差异是非常大的。
那什么样的开发工具才是优秀的、体贴的、以人为本的?我的标准是符合以下四点:
1、能够将要解决的问题简化,并以某种理念快速实现之
2、不隐藏任何你想知道的细节
3、可以忽略你所不想知道的细节
4、主动去适应不同层次的程序员
符合以上四点的开发工具有吗?我的答案是:有!那就是Delphi!她将一切化繁为简,
却从不阻止我寻求真实。你可以在她给你构造的简化了的VCL的虚拟世界中完成任务。也
可以钻进VCL的世界以探询她和现实世界(即Windows平台的真实接口)的映射关系,学
习它的Framework的设计。你还可以扩展那个虚拟的VCL世界以适应自己的需要。
我为存在着这样的开发工具而感到幸运,更为幸运的是,我可以选择她,和她一起完成
我的工作!(现实中,项目中使用什么编程语言、开发工具,时常并不是你个人所能左
右的,会受很多因素制约。比如:客户的硬件环境、操作系统环境,开发环境,开发工
具的成本、许可证等等。因此能选择自己喜欢的开发工具进行开发工作实在是很幸运的
了。)
通过C++学习面向对象的理念,用Delphi去解决现实世界的问题,这是我的做法。同时也
验证了那句话:学从难处学,用从易处用。
真正的程序员用C++,聪明的程序员用Delphi。那么,真正聪明的程序员用C++来理解De
lphi!
1.2 Delphi更多的优势
用过很多的主流开发工具,为什么还是选择了Delphi?也许是因为没有深入地去熟悉其
它开发工具吧,但Delphi本身的优秀至少是原因之一!Delphi优秀在何处?
开发的高效
Delphi是一个RAD(Rapid Application Development 快速开发工具),它有可视化的开
发环境,当然具有类似功能的开发工具也不少(如Visual Basic),但Delphi有如下的
独到之处:
1)Delphi是真正面向对象的。其基于OO技术构建的VCL库中的所有组件都可以被继承以
创建新的组件,包括窗体类TForm。相比之下,ActiveX组件缺乏这种灵活性。
2)Delphi的CodeInsight技术(即代码自动完成功能)是建立在编译器信息上的,而VB
使用的是类型库信息,使用编译器信息的好处是更具灵活性。不过,时常有程序员抱怨
Delphi的代码提示时间太长。其实,我个人感觉是习惯了其速度之后,能体会到一种节
奏的快感。
语言的高效
Delphi基于Object Pascal语言。这是一种真正支持面向对象而又优雅美观的语言。其在
功能的健全上毫不逊色于各种其它的面向对象的语言,但同时又不贪多,盲目地增加复
杂性。使得开发者运用各种模式进行设计时都能得到完善的支持,实现时却不用考虑太
多语言/编译器细节。
编译的高效
可以说,Delphi是Windows平台上最快的高级语言本地代码编译器了。编译速度快有什么
好处呢?快速的编译器可以让你频繁地在修改代码和编译运行的状态间切换。至少,我
自己已经非常习惯了这样的工作方式:运行程序看一下效果,退出程序修改少量代码再
运行程序。而Delphi的编译器从来不会让我有等待的感觉。
执行的高效
Delphi不但编译速度快,生成的目标代码的执行效率也非常高。Delphi与C++Builder
使用的是同一个后端优化器,因此其生成的代码的效率与优秀的C++编译器生成的代码相
同。
Delphi生成完全本地代码,因此Delphi编译结果的可执行文件可以被独立执行、分发(
对于“绿色软件”的开发,这一点十分重要)。不需要其他运行库支持。当然,你也可
以选择动态链接编译,这样可以大大减小可执行文件的长度,不过这种情况下在分发程
序时,必须同时分发必要的运行库文件。
维护的高效
C++把许多决策权给了程序员,因此功能十分强大,但同时,要用C++写出出色的面向对
象的代码,就要求程序员具有一定的素质。而Delphi程序员会在一定程度上被限制在VC
L提供的框架中(当然,完全可以在Delphi中摆脱VCL编程),相对来说,更容易建立良
好设计的代码。而Visual Basic则根本没有提供面向对象的编程机制(VB6.0及先前版本
都是基于对象,而非面向对象)。代码框架的优良使得软件维护成本大大降低。
基于以上所有理由,我选择Delphi!
1.3 本书主题
我们平时都会写很多代码,为公司,为自己或者为朋友。有时,为了验证自己的一个想
法,或学习某一个技术,会写一些试验性的代码。这样的代码的生命周期很短,基本不
需要维护,随意写一下就可以。但是,当你真正要完成一个项目的时候,代码设计就非
常重要。因为这样的代码是需要长期维护,不断修改或增强的。设计凌乱的代码会使得
维护非常困难或者根本不可能,修改这样的代码意味着产生更多的 bug 或者就是灾难。
因此,代码在被编写之前,需要先被设计。这里所说的设计并不是指功能设计,而是指
程序员在编码前先对代码框架的设计,以使得今后代码更容易被理解、被维护。
经常听到一种说法:程序员的程序寿命只有35岁。我却从不相信程序员的寿命只到35岁
,也许35岁以后,实现能力(其实就是工匠能力)有下降的可能,而设计能力是随着经
验的增加不降反升的。这才是最宝贵的。
国外的软件开发小组,一般的骨干都是40岁上下的人,那些才是大师级的程序员,而所
谓的过了35岁就不能当程序员的程序员根本没有资格被称为程序员。
软件工程要将程序员变成编码员,变成流水线上的一环,设计工作由专门的设计师完成
(如框架设计师)。也许,分工细化是趋势,但是,我们是满足于做编码员还是希望成
长为设计师,取决于我们的眼光及努力。
放开眼光,而不是将自己局限于、沉迷于“实现高手”。实现能力是基础,有一定的实
现能力才可能成长,但是,它只是必要条件,而不是充分的。否则,就象爬到山腰就以
为自己到了山顶,停滞不前了。那么,你只可能是编码员,你的程序寿命也只到35岁。
在有了这样的眼光之后,希望本书可以助您起步。
国内出版的Delphi相关书籍,基本都是讲解实现的。本书的书名是《Delphi高手突破》
。那么,假设你现在已经是Delphi高手了。所以本书不会涉及太多的实现技巧,虽然也
有实例代码,但重点在于其构架的设计,而并非实现。
至此,您也许已经猜出本书的主题了:如何在Delphi中使用面向对象技术,构建良好设
计的代码。
在我看来,写代码是艺术创作。优雅的代码可以自解释,而不需要过多的注释。当注释
过多的时候,就该考虑设计是否合理了。写书应该也是艺术创作,如果能把自己的认识
、经验艺术地告诉读者,而不需要过多的“注释”(浪费篇幅的废话),就非常成功了
。我希望自己能做到,至少尽量吧。
1.4 小结
我相信,走上编程这条路,对于我来说是必然的。能成为专业程序员,也是我所梦想并
实现了的。但是,Delphi的出现以及被我所认识、熟悉、迷恋并成为工作的一部分,应
该说是一个意外的惊喜。
在此,我所想说的就是,对于自己的坚持,就更坚持一些吧。当你清醒地定位了自己之
后,清楚地知道自己所选择的道路之后,就不用有所疑问、有所顾忌了,坚持走下去。
最终虽然未必会成功(当然,每个人对成功的定义是不一样的),但爱我所爱,无怨无
悔!
--
深沉忧郁的眼神
玩世不恭的微笑
成熟男人标志--肚子
看似随意的短裤
怀旧风格的拖鞋
※ 来源:·哈工大紫丁香 bbs.hit.edu.cn·[FROM: 天外飞仙]
Powered by KBS BBS 2.0 (http://dev.kcn.cn)
页面执行时间:3.242毫秒