`

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

 
阅读更多
我加入了这

个疯狂的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’结尾的域对象模型时,我可以拿比较熟悉的人员管理域作例子,它可以提升个人素质,使人具有管理行为。

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

相关推荐

    少儿编程行业(2021-2026)企业市场突围战略分析与建议.docx

    本文将对少儿编程行业市场进行分析,并提供相应的战略建议,以帮助企业突破市场困境,获得长期发展。 少儿编程行业概述 少儿编程行业是近年来备受关注的领域,随着计算机技术的发展和普及,编程教育逐渐成为热门...

    一个编程高手写给新手的话

    编程是一项需要持续学习和实践的技能,无论是新手还是...总的来说,成为一个编程高手并非一蹴而就,它需要时间、毅力和不断的学习。新手应遵循这些原则,培养良好的编程习惯,逐步积累经验,才能在编程道路上稳步前行。

    编程原本.pdf

    由于提供的信息中并没有实际的电子书内容,仅仅是一个文件的标题、描述、标签以及重复的链接,因此无法直接生成具体的知识点。考虑到您的要求,我可以基于文件标题和描述中提及的信息,对“编程”这一主题进行知识...

    大数据实验四-MapReduce编程实践

    2. **编写Reduce处理逻辑**:设计一个Reduce函数,对中间结果进行汇总,将所有相同单词的计数值相加,得到该单词在整个文件集合中的总出现次数。 3. **编写main方法**:设置MapReduce作业的配置信息,如指定输入输出...

    儿童编程 第一课.docx

    在这一阶段,孩子们将通过动手操作来学习编程的基本原理,同时在完成项目的过程中获得成就感,从而激发他们继续深入学习的兴趣。 随着预备学习的完成,课程将转入Scratch的基础学习阶段。在这一阶段,孩子们将学习...

    《Java 2游戏编程》

    在游戏编程中,性能优化也是一个不容忽视的部分。Java语言虽然具有跨平台的优势,但在某些情况下可能不如原生代码运行效率高。书中会介绍如何通过优化代码、减少内存开销和使用并发来提升游戏的运行速度。 音频和...

    DES编程实现加解密

    4. 结束置换:最后,经过16轮迭代后的数据会通过一个逆的初始置换IP^-1,得到最终的密文。 在实现中,你可能需要了解以下编程概念: - 密钥管理:如何安全地存储和传递密钥,防止泄露。 - 数据块处理:如何处理不...

    福禄克8508A 编程手册

    福禄克8508A编程手册中还提供了丰富的故障排除指南和日常维护建议。例如: - 当遇到无法正常通信的问题时,检查GPIB或RS-232C接口是否正确连接,确认设备地址设置无误。 - 定期校准以确保测量精度。根据手册中的...

    Windows应用高级编程 C#编程篇

    《Windows应用高级编程 C#编程篇》是一本专注于C#技术在Windows桌面应用程序开发中的高级实践指南。这本书深入探讨了如何利用C#语言的强大功能和.NET Framework的丰富特性,来构建高效、稳定且用户友好的Windows应用...

    编程入门自学指南.pdf

    自学是掌握软件编程技能的一个重要途径。当前有许多自学资源,包括IT图书、在线视频教程以及提供给初学者的免费在线互动课程,这些都使得自学成为可能。然而,自学编程时遇到困难也不必担忧,可以寻求同事或老师的...

    OPENGL高级图形编程

    变换操作是OpenGL图形编程中的一个重要组成部分,包括平移、旋转和缩放等。这些变换操作通常用于改变图形对象的位置、方向和大小。了解OpenGL中的坐标系以及如何使用矩阵来进行变换操作是十分必要的。 #### 7. 光照...

    CODESYS-V3-基础编程指南

    IEC61131-3是工业自动化领域内一个标准化的编程语言,提供了五种结构化的编程语言:指令表(IL)、梯形图(LD)、功能块图(FBD)、结构化文本(ST)和顺序功能图(SFC)。IEC61131-3标准不仅定义了编程语言,还定义...

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

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

    C++编程思想pdf 中文版

    书中还涵盖了模板和泛型编程,这是C++的一个独特特性,它允许编写可应用于多种数据类型的代码。Eckel解释了函数模板和类模板的使用,以及它们如何提高代码的效率和可复用性。 异常处理是C++中另一个重要的主题,它...

    MacTalk·人生元编程.pdf

    通过阅读《MacTalk·人生元编程》,读者不仅可以提升编程技能,还能获得一种全新的思考方式,使个人在职业生涯乃至生活中都能受益。无论你是初入编程行业的新人,还是经验丰富的开发者,这本书都将为你打开一扇新的...

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

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

    【精品教程】游戏编程入门

    【精品教程】游戏编程入门,是一篇专为游戏开发初学者准备的详细指导性...通过本教程的学习,初学者不仅能够获得必要的编程知识,还能够建立起对游戏开发流程的初步认识,为进一步的专业学习和职业发展打下坚实的基础。

    omron PLC 编程手册

    这是程序设计优化的一个关键点,因为了解指令的执行时间有助于开发者评估程序的性能,从而做出合理的程序结构设计和指令选择。确保程序的响应时间满足实时性要求,是高质量工业自动化控制系统的一个重要特征。 附录...

Global site tag (gtag.js) - Google Analytics