zoukankan      html  css  js  c++  java
  • 《代码整洁之道》读后感

      《代码整洁之道》可能对于一个没有从事过编程的读者来说,是相当的抽象,甚至难以理解。但是如果你真正从事过编程工作,尤其是在团队编程,你会有相当深的体会。

    在编程工程中,会不会经常以下感觉:

     1、修改一个bug,会导致其它的bug出现

     2、添加一个本来是很简单的需求,要修改几十个模块,而且容易忽略其中一些小模  

        块,导致bug的产生

     3、接过别人写的代码,很难找到写代码人的意图

     4、在看代码的时候会在满面里面到处跳,最后把自己都搞晕了,不知道看到哪个

        部分了等等

    首先举个例子说说糟糕的代码会导致的后果:曾经有一个很著名的应用-----杀手应用

    刚开始的时候发展的非常好,可是后来却倒闭了,而导致他们倒闭的原因很简单:为了赶着出产品,代码写的乱七八糟,特性越加越多,代码越来越乱,最后没有办法再管理这些代码了。最终导致了这个公司的倒闭。多么    

    在开发的时候,很多程序员明知道自己写的代码可以做重构,可以优化,不过为了赶进度,都会对自己说,先这样将就用一个,等完成了再做重构,再来优化。不过就像勒布朗说的那样:稍后等于永不。等你开发完了,不管是因为忘记还是担心会改出问题来也好,最后都很少去重构优化了,而这一块糟糕的代码就被放在那儿直到没有办法再维持下去。而混乱的代码 结果是什么呢?确实 我们刚刚开发的时候很快,但是后来就越来越慢,对代码的每次的修改会影响的代码越来越多,最后这个代码再也没有办法继续维护了。

    怎样让代码整洁呢?至少要消除重复代码和提高表达力。下面会阐述几点来帮助代码保持整洁。

    首先,要用有意义的命名。怎么才叫有意义的命名呢,第一、要名副其实,尽量用有意义的变量名(以从变量名中知道变量表示的意义)。第二、要避免误导。第三、做有意义的区分。第四、使用读的出来的名称。第五、使用可搜索的名称(名称长短应与作用域大小相对)。第五、方法名应该是动词或动词短语。第六、别用双关语。

    其次,遵循函数的规则。函数最重要的规则就是短小,并且只做一件事,且要做好这件事。函数如果能做到自顶向下的读完一个流程,那这个代码就是很整洁的。沃德原则:如果每个例程都让你感到深合已意,那就是整洁的代码。函数的参数也是越少越好,除非有足够的特殊的理由才能用三个以上的参数。如果参数中出现bool类型,就直接宣布了本函数不止在做一件事。使用异常返回错误代码,函数比较庞大时,尽量做到只有一个入口 ,一个出口。

     最后是注释。若非必要的注释,那注释就是一种失败(因为注释就是为了弥补代码在表达遭遇了失败)。注释存在的时候越入,不离其所描述的代码越远,越来越变的错误 ,原因很简单,程序员不能坚持 维护注释。不准确的注释,要比没有注释坏的多。尽量用代码来替代注释。哪些注释是必须的,也是有得的呢?1、法律信息(代码规范编写与法律有关的注释:版权,著作权就是要天之翼在源文件开头的)2、提供信息的注释3、对意图的解释4、阐释5、警示6、TODO注释。而哪些注释 是没有必要的呢?下面提出了几点:1、误导性的注释2、多余的注释(函数头上的注释都是多余的)3、位置标记4.能用变量或函数时就别用注释5、注释掉的代码(别人不知道为什么,永远不会去删除)

    看完这本书以后再回去看自己参与写过的系统,发现很多地方 存在问题,希望自己以后也能注意到这些问题,写出干净整洁的代码。给自己和以后维护的人都能以赏心悦目的感觉,看自己的代码也像书上所写的一样,看代码就像看一件艺术品.

  • 相关阅读:
    Sublime Text 3插件收集
    Jenkins连接git时出现“Failed to connect to repository : Command ... HEAD" returned status code 128:”的问题解决
    Jenkins错误“to depth infinity with ignoreexternals:true”问题解决
    jeesite导入数据库错误:java.sql.SQLException: Incorrect string value: 'xE4xB8xADxE5x9BxBD' for column 'name' at row 1问题解决
    Maven出现错误No plugin found for prefix 'jetty' in the current project and in the plugin groups的问题解决
    Mac下关闭Sublime Text 3的更新检查
    Ueditor 专题
    Navicat PatchNavicat
    DataSourceBuilder.create().build()
    常用的HTML富文本编译器UEditor、CKEditor、TinyMCE、HTMLArea、eWebEditor、KindEditor简介
  • 原文地址:https://www.cnblogs.com/lijiawei1-2-3/p/14926974.html
Copyright © 2011-2022 走看看