`
lvwenwen
  • 浏览: 956064 次
  • 性别: Icon_minigender_1
  • 来自: 魔都
社区版块
存档分类
最新评论

像建筑设计师一样去写程序

阅读更多

url:http://www.iteye.com/news/27081

 

 写代码和写文章,从某种程度上是相通的,需要逻辑、构架,也要尽可能的简练。我们之前说过,创作者的时间表和管理者的时间表是不一样的,编代码和写文章,都是一个孤独而不能受到干扰的过程,面对屏幕,就是一场自己与自己的战争。 


同样,如果说建筑师最后的成品是建筑的话,那么程序员和软件工程师最终的成品就是软件。在实际动工之前,建筑师将会将建筑的每一个细节,都在蓝图上加以呈现。只是程序员和软件工程师并不会这么做。或许,这就是为什么房子很少倒塌,而软件却经常崩溃的原因? 



设计蓝图会帮助建筑师确定他们的设计是可行的。“可行”并非只是保证不倒塌,它同时还意味着,建筑能够达到预定的服务于人的目标。客户或者开发商,也是通过蓝图去了解一个设计师的想法和他正打算去做的事情。

相较之下,很多程序员在他们开始写代码之前,连一个粗略的框架都没有。 

大部分的程序员都认为:所有不能直接产出代码的事情都是没有意义的。思考并不能直接转换成代码,但是倘若在没有一个整体框架之前,就开始匆忙码字,这也是没有意义的。在程序员开始写代码之前,他们应该先充分理解这些代码最终所要实现的功能。理解的过程,自然需要去思考,而将思考过程写下来,对于程序员来说又是件很耗时的事儿。 

但漫画家 Dick Guindon 曾经所过: 

引用
写作是发现你想法有多糟糕的最好的方式。


蓝图帮助我们理解建筑的构架,同样,在我们开始噼里啪啦写代码之前,我们也需要一个类似的“蓝图”,也就是“注释”(specification)。 

“注释”不能直接产出代码,所以被很多程序员忽视。但没有“注释”,直接开写,就好像让建筑承包商没有设计师的图纸就直接上阵一样。 

也有人会说,将程序员和建筑师类比,并不合理。因为拆墙重建困难,但删掉重写则相对容易,所以,程序员可以先写着,不满意再改。 

这种想法是错的。为什么呢?因为 Debug 的过程也非常耗时。 

我最近也完善了一些程序,这个过程需要对程序构架本身有个非常清晰的了解。我花了接近一天的时间去了解整个程序的运作机制,而倘若有注释的话,这可能只需要 5 分钟的时间。 

为了避免引入 bug,我需要理解任何小的调整可能带来的结果。而没有注释,使得我必须花很长时间了解每条代码的含义和作用。尤其对于上千行的代码来说,首先读懂它就很耗时,想要改掉其中的某行,我必须了解小的调整可能对整体架构和前后逻辑造成的影响。最终,在超过一个星期的时间里我只改了 180 行代码,而这对一个动辄千行的程序来说,改变算是很小的了。 

Debug 只是写代码一个小的组成部分。这数千行的代码很多我 10 年前写的,尽管我对它们仍有些许残存的记忆,但如果有注释的话,修改代码的过程会更加顺畅,我不仅能在最短的时间里读懂整个框架,还可以准确定位我所要修改的部分。 

改别人的代码就更加困难了,每个人的思维方式都不一样,如果没有注释,我通常要花费两倍以上的时间,只是为了修改一些细小的错误。 

那么,我所谓的“注释”又是指什么呢?“注释”是指附在代码之后的,一段形式化规范说明的文字。但需要区分开的是,如果只是去打造一个工具室,我们是不需要一整套摩天大楼蓝图的,同样,对于小的算法来说,我们也不需要给每条代码加上注解。 

我最近要编写的程序,最多称得上是“平房”,而非摩天大楼。我会为我的每个算法附上注释,有些非常简单的算法,我通常只会插上一两句注解。我有一个非常简单的法则来帮助我和其他人了解我的程序:注释应该尽可能有效地去帮助任何一个人理解和使用我的代码。 

一旦我知道一行特定代码要做的事情后,写的过程其实是非常简单而直接的。也有些程序需要用到非常规算法,这时我会写下我算法的主要思路,来试探其可行性,同时也帮助我更高效的 Debug。 

除了那些特别重要的代码,通常我的注释都是非正式的。在过去的十年里,需要我写准确并正式注释的次数并不多。但对于一个非常复杂的系统来说,注释的重要性不言自明。很少有工程师会在构建一个复杂系统时,花时间去写好注释。有些学校也会教你怎么写注释,但更多时候都是教你如何写好代码。这需要实践,如果你没有画过搭建一座平房的图纸,你很难直接画出摩天大楼的蓝图。 

写好注释也没有一个简单的准则,但有一点你要尽量避免,那就是用代码去解释代码。就好像你不能用两个人们都不理解的东西,用其中一个去解释另外一个。建筑师也不能直接用砖块来告诉你,他想搭建一个什么样的房子。 

了解一个复杂的系统,最好的办法就是将其核心用简单的概念,抽象的概括出来。初中数学的一些基本概念可以用来帮助你写好注释,比如你可以用一些集合、方程和简单的逻辑来解释你的代码。对于一些复杂的算法,你也可以引入数学里没有过的概念来加以解释。总的来说,如果你的注释偏离一些抽象的数学基本概念越远,理解起来也就越困难。 

思考并不能保证我们不犯错,但不思考,犯错是无法避免的。注释能帮助我们将错误最小化,同时它还能提高我们改错的效率,节省我们的时间。 

分享到:
评论

相关推荐

    首席建筑师Trusses教程

    【首席建筑师Trusses教程】是关于建筑设计软件《Chief Architect》中如何使用屋顶桁架功能的指导。在建筑设计中,屋顶的构建主要有两种方法:一种是stickframe,也称为手动堆叠,涉及椽子、山脊和天花板搁板等组件;...

    天正建筑命令快捷键大全.pdf

    在天正建筑中使用快捷键,可以有效提高绘图效率,减少重复劳动,使得建筑设计工作更加便捷。 知识点三:常用天正建筑快捷键举例 虽然文档内容无法解读,但基于天正建筑软件的一般知识,我们可以列举一些通用的CAD...

    信息技术及应用引论.docx

    在职业岗位和知识体系方面,课程涵盖了多种角色,如计算机应用工程师、硬件维护工程师、网页设计师、数据统计分析师、网络应用工程师、平面设计师、室内设计师、景观设计师、建筑设计师、产品造型设计师、服装设计师...

    cad统一标高小插件

    建筑设计师画工程图时经常遇到图层不在一个水平面,这样没法倒角和操作,cad中加载此插件,命令行输入qq,即可完成标高的统一!

    3D地毯模型设计

    在3D地毯模型设计领域,设计师们利用专业的三维软件来创建逼真的地毯纹理和形态,以便于在室内设计、游戏开发、电影制作等场景中应用。这个主题涵盖了许多技术细节和流程,包括软件使用、纹理制作、建模技巧以及渲染...

    犀牛TS 文件

    T-Splines 插件的核心功能在于它的可编辑网格技术,这使得设计师可以像处理多边形模型一样对NURBS模型进行操作,无需担心损失细节或精度。在传统的NURBS建模中,添加或移除控制点可能会导致复杂的几何形状难以调整,...

    中文3DMAX种草画笔GrassPainter下载

    通过这款插件,用户可以像使用传统绘画软件一样,自由地在3DMAX场景中绘制草丛。选择不同的画笔形状和纹理,可以模拟出不同种类和形态的草。此外,GrassPainter还支持自定义参数设置,如草的高度、密度、生长方向等...

    EDA三层电梯设计,MAX+PLUSⅡ VHDL 仿真

    它允许设计师以类似于软件编程的方式描述硬件行为,简化了复杂系统的建模和验证。 电梯控制系统的设计遵循方向优先原则,即电梯在上升模式时响应高层的上楼请求和电梯内乘客的下楼请求,而在下降模式时则相反。设计...

    CAD2000下AutoLISP编程及应用.pdf

    加载后,程序中定义的新命令和功能就可以直接在AutoCAD中使用,就像使用AutoCAD自带的功能一样。 6. 关键词解析 - AutoLISP编程:指利用AutoLISP语言进行的编程活动,旨在通过编写AutoLISP程序来扩展AutoCAD的功能...

    t-splines4-zh.rar

    描述中的“插件”一词表明 T-Splines 是为 Rhino 添加新功能的程序模块,让设计师能够利用更先进的建模方法,特别是在设计曲线和曲面时,能更好地处理复杂的几何形状和有机形态。 标签 "rhino 插件" 明确了 T-...

    cad窗口切换软件

    描述中提到的“同天正建筑一样切换不同图纸”,天正建筑是一款基于AutoCAD平台的专业建筑设计软件,拥有丰富的建筑绘图和编辑功能。这里的比较意味着这款名为“DocBar”的插件也提供了类似的功能,即在处理多个建筑...

    免费的CAD图纸浏览器

    最后,描述中提到它可以“像AutoCAD一样操作”,虽然可能无法提供AutoCAD的所有高级编辑功能,但至少具备基本的浏览和导航功能,比如平移、缩放、旋转视图等,确保用户能像在专业CAD软件中一样浏览图纸。 标签中的...

    地铁模拟:从地铁窗口观看的程序化城市景观。 像素图,体积渲染和程序资产的组合

    这种技术可以大大减少设计师的工作量,同时确保每次运行或每个玩家看到的场景都有一定的独特性。 2. **像素图**:像素图是一种数字艺术形式,其中图像由单个的彩色小块组成,就像拼图一样。在地铁模拟中,可能用...

    Pocketdoor Add Item-crx插件

    语言:English 从您正在查看的URL向Pocketdoor...Pocketdoor提供的应用程序可使建筑师,设计师,承包商和房主更加享受家装项目。 不要用电子表格和电子邮件管理您的产品购买! 使用Pocketdoor可使每个人都在同一页面上。

    基于模具CAD的孔系自动识别.pdf

    AutoCAD是由美国Autodesk公司开发的一款专业CAD设计软件,广泛应用于工程制图、工业设计、建筑设计、机械设计等领域。通过AutoCAD,工程师可以绘制出精确的二维和三维模型,并进行后续的设计分析与修改。 VB即...

    异构CAD协同设计系统的集成与实现.pdf

    不同CAD软件之间没有形成一个完整的系统,信息共享程度较低,信息传递速度慢,项目无法实时监控,应用系统集成效率不高,导致这些问题的原因有多个,其中包括不同设计师可能擅长使用的CAD软件不一样。为解决这些问题...

    Pocketdoor添加项目「Pocketdoor Add Item」-crx插件

    从您正在查看的网址向...Pocketdoor提供的应用程序可使建筑师,设计师,承包商和房主更加享受家装项目。 不要用电子表格和电子邮件管理您的产品购买! 使用Pocketdoor可使每个人都在同一页面上。 支持语言:English

    宾馆改造工程施工组织设计方案范本.pdf

    - 招标文件和设计施工图:作为施工的主要依据,确保按照业主和设计师的要求进行改造。 - 国家建筑规范:遵循国家现行的建筑安装、施工技术规范和验收标准。 - 现场实际情况:通过现场勘察,了解建筑现状,制定...

    cad插件

    除了专门为建筑设计编写了大量功能外,本工具还针对AutoCAD 的弱项,如文字处理、 图库编辑管理、图层管理等,为用户提供了一个非常好的解决方案。 4. 因每个人的缩写命令习惯不一样,本工具不修改缩写命令文件...

Global site tag (gtag.js) - Google Analytics