`
zhangziyangup
  • 浏览: 1082749 次
文章分类
社区版块
存档分类
最新评论

我曾经得到的一个最好的编程建议

 
阅读更多

多年以前(早在1992年),我加入了一个疯狂的科研项目(skunkworks),该项目使用了一种另类的编程语言——Smalltalk。当时“面向对象”这个术语才刚兴起不久。作为“面向对象”的顾问,报酬非常可观。很多人自以为这就是新的对象派别的全部内容。在这5年后,Alan Kay说了这句话:“我发明了‘面向对象编程’这个术语,但{Java和C++}跟我所知道的有所不同”。(”I invented the term ‘Object Oriented Programming’ and this {Java and C++} is not what I had in mind.”)

在加入这个奇特的小组,使用这种奇怪的编程语言不久之后,我依然对实例变量、类变量、类实例变量之间的差别感到困惑。我参加了来自ParcPlace的Russ Pencin的培训课程。他说了一些当时我很不喜欢的东西。尽管不明白金玉良言当中的要点,但我还是努力跟上进度。这需要多年的经验才能渐渐体会其中的价值。建议是?

在给对象命名时,不要使用‘er’结尾Don’t make objects that end with ‘er’.)

没错。面向对象编程(OOP)的模式在我们称之为“程序化编程”的文化当中活力十足。现在我们没有过多地谈论这两种模式之间的对比。也许一部分是因为面向对象语言现在俯拾即是。面向对象编程流派,在众多派别中脱颖而出。可惜的是,我经常回想起我在2000年左右听过 Adele Goldberg的演讲:“现在我们有很多面向对象编程技术,但就没有那么多面向对象编程的程序员”。假如我有一个建议想转告给一群有志成为面向对象程序员的人,那应该是Russ提供的一句金玉良言:“在给对象命名时,不要使用‘er’结尾。”

这名字到底意味着什么呢?为什么值得人们对它如此兴奋?多年以后我发现,面向对象编程的精髓在于将行为绑定在数据上。在你还没成为他们无归属组织的重要一员时,程序就还是由行为和数据构成。在典型的结构化程序设计之中,我们将精力集中在行为(动词)上,然后弄清楚我们需要哪些数据(名词)才能执行。总而言之,我们将数据绑定在行为上。但在面向对象程序设计之中,我们将程序的中心用名词和数据表示,然后弄清楚我们要将哪些行为绑定在他们之上,希望这些我们想要解决的问题能够在突发的行为中得到答案。

最近我觉得有一个更好的名字来形容一位同事差不多都插手过的每一个“er”对象例子。

给例子起一个更好的名字会让设计更加具有独立性,代码的关联性更少,总之,更加面向对象。这不是硬性规定,不过这会让很多例子得到改善。

就拿某种“装载程序模块”来说吧,重点在于它的工作单元。模块有许多实例变量,参数,也许还有很多到处传输的数据。如今,取而代之的是LoadRecord和LoadStream。我有理由相信,你们最终使用的工具,更类似于面向对象编程创始人心中设想的模样。我们想要创造可以描述的对象,然后将某些行为绑定在它上面,而不是将焦点集中在它的行为上,然后弄清楚他们的行为需要哪些数据。

某些以前学过的用er结尾的对象已经绝迹多年

管理者(Manager)——每当我遇到一位管理者时,我就会感到担忧。大家没有跟我说它的含义,却早早地告诉我它的职能。它是注册表吗?那就叫它注册表吧。是历史记录还是日志?就那样称呼吧。是工厂吗?就那样称呼吧。

控制器(Controller)——我在过去20年内只做过一个上等的控制器对象,它是一个象征着现实世界对象的BallastVoltageController接口。事实上,世界上每一个简单MVC的执行与控制器的不同作用本应告诉我们这个构想相当协调的事情。

组织者(Organizer 以及许多类似的团体)——焦点在于他们的职能。这是一个用来说明让众多这种‘ers’对象转化为组织极其简单的不错例子。就把它们称为组织吧。现在我们来关注它们的内容。

分析器/渲染器/(Analyzer/Renderer)/等等——“劳动者”对象中定义清晰的例子。假设它们是用来分析/渲染/等等。

生成器/加载器/阅读器/编写器/(Builder/Loader/Reader/Writer/)等等——把焦点从被操控的对象身上挪开,它们自身往往承担着重大的责任。

这样一条路线规则也会有很多例外

有许多以‘er’结尾的名词。注册表、边框、字母、数字。如果真的是一个名词的话,那就好了。

有很多‘er’结尾的单词,尽管重点在于它们的行为上,也变得很常见了,所以我们最好至少在一定程度上维持这种情况。分部程序,编译器,浏览器。

当你试图建立一个以‘er’结尾的域对象模型时,我可以拿比较熟悉的人员管理域作例子,它可以提升个人素质,使人具有管理行为。

你的经历可能会有所不同,我相信有很多人持反对意见。直到你适应了这种心态一段时间之后,你才能真正体会到。为你的项目/设计提供一个回旋的余地,看看会发生什么。

英文原文:One of the Best Bits of Programming Advice I ever Got


分享到:
评论

相关推荐

    大数据实验5实验报告:MapReduce 初级编程实践

    林子雨大数据原理与技术第三版实验5实验报告 大数据技术与原理实验报告 ...并剔除其中重复的内容,得到一个新的输出文件 C。下面是输入文件和输出文件的一个样例 供参考。 输入文件 A 的样例如下:

    程序员编程艺术第一~三十七章集锦

    从2011年4月写下第一篇至今,编程艺术系列已经写了37章,也就是说详细阐述了37个编程问题,在创作的过程当中,得到了很多朋友的支持,特别是博客上随时都会有朋友不断留言,或提出改进建议,或show出自己的思路、...

    程序员编程艺术第一~三十七章集锦 高清完整PDF版

    从2011年4月写下第一篇至今,编程艺术系列已经写了37章,也就是说详细阐述了37个编程问题,在创作的过程当中,得到了很多朋友的支持,特别是博客上随时都会有朋友不断留言,或提出改进建议,或show出自己的思路、...

    AI编程助手Bito中关于Prompt的使用介绍

    - 创建一个角色 - 3、更多Prompt资源推荐 二、适合人群:本教程适合对AI感兴趣的程序员群体,希望借助AI编程助手辅助开发,或对Prompt感兴趣的人员。 三、能学到什么:1、了解Prompt的基本概念,2、介绍了关于...

    delphi经典编程入门

    缺省的应用程序是一个空白的窗体(Form),您可以运行它,结果得到一个空白的窗口。这个窗口具有Windows窗口的全部性质:可以被放大缩小、移动、最大最小化等,但您却没有编写一行程序。因此,可以说应用程序框架通过...

    OPenGL编程书籍

    理解OpenGL如何工作非常重要,你可以在教程的末尾下载源程序,但我强烈建议你至少读一遍教程,然后再开始编程. 2.你的第一个多边形: 在第一个教程的基础上,我们添加了一个三角形和一个四边形。也许你认为这很简单...

    Tcl_TK编程权威指南pdf

    我一直使自己在很大程度上保持着一个Tcl程序员的角色,而我们工作组中的其他人员则埋头于Tcl本身的C语言实现。我创建的应用程序有HTML编辑器、EMAIL比用户接口程序、Web服务器以及用户数据库,我们的商务应用就建立...

    编程真的适合你吗?一个老程序员的建议

    一个老程序员的建议。看完了这本书,你决定继续做编程。也许它能成为你的一个职业,也许它能成为你的一项爱好。但你需要一些指导,确保自己不会走错了道路,或帮助你从这个新业余爱好中得到最大的乐趣。  看完了这...

    高质量C++编程指南

    海贝尔网络应用事业部的一个规范化文件,同时作为培训教材。 由于 C++/C 编程是众所周知的技术,没有秘密可言。编程的好经验应该大家共享, 我们自己也是这么学来的。作者愿意公开本书的电子文档。 版权声明如下: ...

    AVR编程与实例

    ICCV7,AVR编程。迎您使 用 A V R 单片机 开发板 !我们非 常高兴您选择了本 款产 品 。 我们将为您提供最真诚最优质的服务 。 为了使我们的产品得到充 分发挥 , 我们建议在连接和操作之前 , 通读一遍使用说明书 ...

    UNIX环境高级编程

    3.11.1 添加至一个文件 45 3.11.2 创建一个文件 45 3.12 dup和dup2函数 46 3.13 fcntl函数 47 3.14 ioctl函数 50 3.15 /dev/fd 51 3.16 小结 52 习题 52 第4章 文件和目录 54 4.1 引言 54 4.2 stat, fstat和lstat...

    XML高级编程

    这是因为查询技术的一个子集允许编程者指定一个标准集,用来选择文档中必须样式化的部分。样式化要精确到能够指定如何根据特定元素所处位置的上下文关系来实现。相同类型的元素可能因为它们父元素的不同,或者周边...

    程序员编程艺术第一~三十七章集锦by_July

    从2011年4月写下第一篇至今,编程艺术系列已经写了37章,也就是说详细阐述了37个编程问题,在创作的过程当中,得到了很多朋友的支持,特别是博客上随时都会有朋友不断留言,或提出改进建议,或show出自己的思路、...

    python 核心编程

    Python(KK 英语发音: /'pa?θɑn/, DJ 英语发音: /?paiθ?n/),是一种面向对象、直译式...这的确是一个中肯的建议,对于那些从来没有学习过编程或者并非计算机专业的编程学习者而言,Python是最好的选择之一。

    中文第一版-UNIX环境高级编程

    3.11.1 添加至一个文件 45 3.11.2 创建一个文件 45 3.12 dup和dup2函数 46 3.13 fcntl函数 47 3.14 ioctl函数 50 3.15 /dev/fd 51 3.16 小结 52 习题 52 第4章 文件和目录 54 4.1 引言 54 4.2 stat, fstat和lstat...

    精通qt4编程(源代码)

    \ 第5章 布局管理 卢传富布局管理是GUI应用程序编程的一个重要方面。Qt提供了多种布局管理部件,包括Qt布局管理器、分裂器、栈部件、工作空间部件和多文档区部件等。本章一一介绍了这些部件,并举例说明了它们在图形...

    高质量C++编程指南.zip

    前 言 6 第1章 文件结构 11 1.1 版权和版本的声明 11 1.2 头文件的结构 12 1.3 定义文件的结构 13 1.4 头文件的作用 13 ...我曾经也这样信奉,并且希望自己成为那样的“真正”的程序员,结果没有得到好下场。

Global site tag (gtag.js) - Google Analytics