美文网首页
整理《编程的智慧》

整理《编程的智慧》

作者: Chenstyle | 来源:发表于2016-09-20 12:03 被阅读124次

    前言

    王垠的《编程的智慧》一文,从第一次读到现在,已经过了许久。从第一次看的时候就感觉这文章十分的厉害,大概是我没十几年的从业是写不出来的状态。全文说的很好,我很多时候也按照其中去做。但是很多时候总是不得要领,所以总是在闲暇之余打开看了一遍又一遍。想着要把文中的习惯和好的做法融入到自己写的代码中去,所以就觉得是应该整理一下,以自己的方式记录出来,也比较好形成一个直观的概念,在写代码的时候方便一些。

    说这些的时候总是会想起王垠提出过很多次的教条主义,无奈在我看来,教条主义有时候真的是一个好东西。毕竟不是每个人都能把一门技艺磨练的炉火纯青,信手拈来。所以我们需要准则来告诉我们,什么时候该做什么,什么时候不该做什么。虽然不会有很多创新和多大的提高,最起码,不会捅篓子。生活在集体之中,对这一点要尤为注意。


    全文小标题

    1. 反复推敲代码

       By me: 写的时候记得要把当时预料到的坑给TODO一下,不然过后也就忘记了,打注释也好。另外就如文中所说,过阵子再回来看这部分代码,又会有不一样的感觉。
      
    2. 写优雅的代码

       if语句最好有两个分支。写代码说起来总归是线性的,所以逻辑要整理清楚。先哪一步,后哪一步。
      
    3. 写模块化的代码

       - 避免写太长的函数
       - 制造小的工具函数
       - 每个函数只做一件简单的事情
       - 避免使用全局变量和类成员来传递信息,尽量使用局部变量和参数
      
    4. 写可读的代码

       - 使用有意义的函数和变量名字
       - 局部变量应该尽量接近使用它的地方
       - 局部变量名字应该简短
       - 不要重用局部变量
       - 把复杂的逻辑提取出去,做成“帮助函数”
       - 把复杂的表达式提取出去,做成中间变量
       - 在合理的地方换行
      
    5. 写简单的代码

       - 避免使用自增减表达式
       - 永远不要省略花括号
       - 合理使用括号,不要盲目依赖操作符优先级
       - 避免使用continue和break.*这一条对switch...case中的break不适用*
      
    6. 写直观的代码

       即使嵌套if也不要使用多重的&&和||
      
    7. 写无懈可击的代码

       if语句分支最好考虑到极端状况,也就是说最好要有else,在里面处理一些东西。
      
    8. 正确处理错误

       异常需要去处理,而不是仅仅的抛出。
      
    9. 正确处理null指针

       - 尽量不要产生null指针。尽量不要用null来初始化变量,函数尽量不要返回null
       - 不要`catch NullPointerException`。在可能出现null的地方检查一下,然后处理
       - 不要把null放进“容器数据结构”里面
       - 函数调用者:明确理解null所表示的意义,尽早检查和处理null返回值,减少它的传播。
       - 函数作者:明确声明不接受null参数,当参数是null时立即崩溃。
       - 使用@NotNull和@Nullable标记。
       - 使用Optional类型。*这个目前不需要,因为java8里面很蹩脚*
      
    10. 防止过度工程

      - 先把眼前的问题解决掉,解决好,再考虑将来的扩展问题。
      - 先写出可用的代码,反复推敲,再考虑是否需要重用的问题。
      - 先写出可用,简单,明显没有bug的代码,再考虑测试的问题。

    相关文章

      网友评论

          本文标题:整理《编程的智慧》

          本文链接:https://www.haomeiwen.com/subject/vjcoettx.html