`

代码洁癖症的表现

阅读更多

有下列情形之一的,你患上了代码洁癖症。症状程度可轻可重,轻者帮助写出优雅整洁的代码,重者走火入魔,万劫不复。

  1. 多余的空行、分号,没有使用的变量,见一个删一个。
  2. tab或者空格没有对齐的必须纠正过来,除了缩进用,不允许看到代码内连续两个空格。
  3. 看到一个类某个方法没有注释,不由自主地加上,不管有没有意义。
  4. 错误的拼写,无论是在命名还是注释必须纠正过来;不一致的大小写,必须要纠正过来;标点符号的遗漏,必须补上。
  5. 看到if(a==0)这样的代码必须改成if(0==a)这样的形式。
  6. 所有IDE对代码的告警必须消除,无论采取的方式是否有实际意义。
  7. 看到赤裸的数字,必须定义成常量,即便数字表意很直观,还是只能接受常量数字。
  8. 见不得非静态的公有变量,必须建立get/set方法。
  9. 不断地按代码格式整理的快捷键,在Eclipse就是不断地CTRL+Shift+F、CTRL+Shift+O,甚至不住地CTRL+S。
  10. 一旦看到超过连续3个的if-else判断分支,就要优化;类似的方法调用代码,如果连续出现,就要优化;超过若干行的方法,必须重构。
  11. 最本质的表现,喜欢长时间阅读自己的代码,心中一边啧啧赞赏不已,一边自我陶醉。

文章系本人原创,转载请保持完整性并注明出自《四火的唠叨》

47
10
分享到:
评论
69 楼 liukai 2013-02-25  
liukai 写道
    function (parameter) {  
       boolean result = false;

        if( condition == true) {  
      
            //省略若干行代码  
           result  = true ;  
      
        }  
      
        //省略若干行代码  
        return result


标记器不好用啊

68 楼 liukai 2013-02-25  
    function (parameter) {  
       boolean result = false;

        if( condition == true) {  
      
            //省略若干行代码  
           result  = true ;  
      
        }  
      
        //省略若干行代码  
67 楼 liukai 2013-02-25  
songgz 写道
lg_asus 写道
Nightlee 写道
witcheryne 写道
中了不少抢...

多层 if 嵌套也会受不了.
想都不想就用 if-else 也受不了.

function (parameter) {

    if( condition == true) {

        //省略若干行代码
        return a;

    } else {

        //省略若干行代码
        return b;
    }

}


我就特么的想改成:

function (parameter) {

    if( condition == true) {

        //省略若干行代码
        return a;

    }

    //省略若干行代码
    return b;

}


这个写法其实有弊端,代码中间的return相当于变相的goto,破坏了代码的顺序,还是喜欢if-else里面赋值最后再return

这种写法叫做guard clause


function (parameter) {

    if( condition == true) {

        //省略若干行代码
        return a;

    }

    //省略若干行代码
    return b;

}

这个写法是效率最高的,只有了解计算机体系结构的大师,才深谙此道,经常如此用。
代码的好坏,不仅仅是形式和逻辑上的。
function (parameter) { if( condition == true) { //省略若干行代码 return a; } //省略若干行代码 return b; }
66 楼 anhui3713 2013-02-25  
kidneyball 写道
youarestupid 写道
RayChase 写道
kidneyball 写道
runfriends 写道
我一直想知道过多的if-else怎么优化。有很多时候只能使用if-else做判断


如果每个分支做的事情很简单且分支不大可能增加可以改为switch。如果每个分支做的事情比较多,或者将来有可能增加分支可以改为责任链模式。


评论里说的对于过多if else优化的方式都不对,至少是很片面的,我去写一篇怎么重构过多if else的文章。

应该是策略模式。


对于替代单一位置的复杂if分支,策略模式只能替代单选分支的情况(如果一个客户类会持有一串策略类实例依次调用,就变成责任链了),责任链则可以通吃。每个匹配的责任链结点处理后不向后传递控制,可替代if...else if...else if...的情况。处理后继续传递控制,则可替代if...; if...; if...;的情况。每个结点还有机会改变或封装传入参数,影响后续的结点。而且每个结点可以拆出来单独使用,或者重新组合。对于替代内部的分支结构,个人感觉更为灵活。

策略模式的强项是处理同一分支结构在多处反复出现的情况(责任链其实也能用于这种情况,但太过抽象,无法向实现者传递设计意图)。在设计框架性的API时,策略模式能限定实现者必须实现的接口,和通过接口向实现者传递一些设计意图。



很多if问题如果是判断我也不太喜欢用switch,个人喜欢把每个逻辑代码封装起来然后通过map实现key-value的映射然后来调用对应的代码执行...基本上省去了判断的过程...虽然效率低很多..但是代码简洁不少
65 楼 jazzmozart 2013-02-25  
jazzmozart 写道
哈哈,第14条还真是走火入魔了

11条
64 楼 jazzmozart 2013-02-25  
哈哈,第14条还真是走火入魔了
63 楼 yanmingeye 2013-02-25  
  我很多缺点都有
62 楼 songgz 2013-02-25  
lg_asus 写道
Nightlee 写道
witcheryne 写道
中了不少抢...

多层 if 嵌套也会受不了.
想都不想就用 if-else 也受不了.

function (parameter) {

    if( condition == true) {

        //省略若干行代码
        return a;

    } else {

        //省略若干行代码
        return b;
    }

}


我就特么的想改成:

function (parameter) {

    if( condition == true) {

        //省略若干行代码
        return a;

    }

    //省略若干行代码
    return b;

}


这个写法其实有弊端,代码中间的return相当于变相的goto,破坏了代码的顺序,还是喜欢if-else里面赋值最后再return

这种写法叫做guard clause


function (parameter) {

    if( condition == true) {

        //省略若干行代码
        return a;

    }

    //省略若干行代码
    return b;

}

这个写法是效率最高的,只有了解计算机体系结构的大师,才深谙此道,经常如此用。
代码的好坏,不仅仅是形式和逻辑上的。
61 楼 zoven 2013-02-25  
中了大部分
60 楼 zhoujiangjohn 2013-02-25  
rox 写道
搞IT的,多半都会有些强迫症。

本人就有点。
59 楼 programmer 2013-02-25  
悲剧,好像说的是我
58 楼 小鑫。 2013-02-25  
躺枪,重度洁癖,外加强迫症。
57 楼 lake85520 2013-02-25  
同样的事情,有人认为是洁癖,也有人会认为是细节,见仁见智吧。上面的那些现象,曾经或者现在都一直保持着,哈哈。只要有空余的时间,总喜欢重构代码,提升效率。有些时候算一种自我陶醉,更多时候是为了避免麻烦呵。写一手漂亮的代码最起码好过写一手糟糕的代码,不仅自己看着舒服,修改起来方便,也能给别人一种舒心的感觉,最起码不反感。让人乐意去看你的代码,才有心情去修改。相当反感下班或者休假的时候接到工作上的电话,所以写有“洁癖”的代码也算给自己免除不必要的麻烦吧,呵呵。工作中付出的多一点,生活中就享受多一点。
56 楼 thierry.xing 2013-02-25  
全部中枪
55 楼 cometlj 2013-02-25  
顶你一个 代码洁癖症
54 楼 kidneyball 2013-02-25  
kidneyball 写道

此外,策略模式只适用于条件可以提前到注入阶段进行判断,注入后与条件有关的状态不再发生变动的情况。如果你的if分支依赖于一个运行期经常改变的量,那你在每次调用策略前都要根据同样的一组if判断去创建相应的策略实例,那就是多此一举了。事实上有不少应用在创建策略实例的工厂里还是用了责任链,换句话说,策略模式的作用是把多个相同的分支结构统一为一个,并且提前到注入期进行一次性判断。而责任链则实际取代了这个分支结构。


再絮叨絮叨,Java里使用策略模式取代分支一种常见的做法是enum上挂一个策略实例。同样只能用于单分支场景。这种做法本质上是把策略挂到数据(不一定是enum)上,只能用于一个数据恰好对应一种策略的情况,不能满足复杂的条件判断(否则把条件对应到数据又是一堆if)。但如果刚好能满足实际需求的话,倒是一种很直观的做法。
53 楼 silence945 2013-02-25  
全中枪了。。。
52 楼 kidneyball 2013-02-25  
youarestupid 写道
RayChase 写道
kidneyball 写道
runfriends 写道
我一直想知道过多的if-else怎么优化。有很多时候只能使用if-else做判断


如果每个分支做的事情很简单且分支不大可能增加可以改为switch。如果每个分支做的事情比较多,或者将来有可能增加分支可以改为责任链模式。


评论里说的对于过多if else优化的方式都不对,至少是很片面的,我去写一篇怎么重构过多if else的文章。

应该是策略模式。


此外,策略模式只适用于条件可以提前到注入阶段进行判断,注入后与条件有关的状态不再发生变动的情况。如果你的if分支依赖于一个运行期经常改变的量,那你在每次调用策略前都要根据同样的一组if判断去创建相应的策略实例,那就是多此一举了。事实上有不少应用在创建策略实例的工厂里还是用了责任链,换句话说,策略模式的作用是把多个相同的分支结构统一为一个,并且提前到注入期进行一次性判断。而责任链则实际取代了这个分支结构。
51 楼 kidneyball 2013-02-25  
youarestupid 写道
RayChase 写道
kidneyball 写道
runfriends 写道
我一直想知道过多的if-else怎么优化。有很多时候只能使用if-else做判断


如果每个分支做的事情很简单且分支不大可能增加可以改为switch。如果每个分支做的事情比较多,或者将来有可能增加分支可以改为责任链模式。


评论里说的对于过多if else优化的方式都不对,至少是很片面的,我去写一篇怎么重构过多if else的文章。

应该是策略模式。


对于替代单一位置的复杂if分支,策略模式只能替代单选分支的情况(如果一个客户类会持有一串策略类实例依次调用,就变成责任链了),责任链则可以通吃。每个匹配的责任链结点处理后不向后传递控制,可替代if...else if...else if...的情况。处理后继续传递控制,则可替代if...; if...; if...;的情况。每个结点还有机会改变或封装传入参数,影响后续的结点。而且每个结点可以拆出来单独使用,或者重新组合。对于替代内部的分支结构,个人感觉更为灵活。

策略模式的强项是处理同一分支结构在多处反复出现的情况(责任链其实也能用于这种情况,但太过抽象,无法向实现者传递设计意图)。在设计框架性的API时,策略模式能限定实现者必须实现的接口,和通过接口向实现者传递一些设计意图。
50 楼 sanshizi 2013-02-25  
支持代码洁癖症

相关推荐

    【代码洁癖症】第1回-简单工厂模式

    【代码洁癖症】第1回-简单工厂模式 序言 在一个宁静的午后,我有幸拜读了程杰大鸟的《大话设计模式》 觉得这是一本不可多得的好书 奈何里面都是C++代码写的示例,对于学Java的同学不是很友好 于是想将书中的核心提炼...

    无法理喻的文字洁癖

    这种对文字的坚守,表现出文人对作品的尊重和对自身创作原则的坚持。 其次,文字洁癖也体现在对作品内涵的诠释上。北宋时期的文人章卜为苏东坡的诗写注解,耗费多年心血完成了数十册注释。当有人指出其注解中遗漏了...

    Android代码-Componentization

    由于业务增长引起项目中代码量激增,以及历史遗留问题和结构混乱,作为一个有代码洁癖的程序员,很早就开始思考如何组织 App 架构的问题了。目前遇到的主要有以下几点问题: 代码量激增引起结构混乱 各个模块相互...

    男人有感情洁癖该办.doc

    【感情洁癖】是指在情感关系中,个体对伴侣的情感历史、交际圈子或者与异性的互动持有过度敏感和苛刻的标准,常常希望对方的感情经历尽可能简单或者无暇,甚至不容许提及前任。这种情况在现代社会中并不少见,无论...

    Android代码-Android-ConvenientBanner

    而这个库能让有代码洁癖的你欢喜,不需要对库源码进行修改你就可以使用任何你喜欢的网络图片库进行配合。 Demo 用模拟器运行的效果,鼠标拨动和模拟器太卡等原因,实际效果比效果图更炫哦~~ demo代码请看戳这里 ...

    vue语法自动转typescript(解放双手)

    公司目前前端项目大部分都是 vue,早期没有 ts这个说法,后来新项目才逐渐引入 ts,所以新项目用的是 vue-ts,而一般想抄的老代码都是没有引入 ts的,固然,这二者是可以兼容存在的,但对于有着轻微代码洁癖的我来说...

    封装 RecyclerViewAdapter ,可以不用写 ViewHolder, 支持添加 head 和 foot, 支持 head 和 foot 的点击事件

    RecyclerView 可以通过 getItemViewType() 去区分不同的布局, 很明显从这里下手是正确的选择, 但是每个 Adapter 都写大量相同的代码这样对于一个有着代码洁癖和强迫症的人 (其实指的就是我) 很明显是打心里抵触的。...

    通用的吊炸天广告栏,无限循环,各种翻页特效,少量代码就能实现你的需求

    通用的广告栏控件,让你轻松实现广告头效果。支持无限循环,可以设置自动翻页和时间(而且非常智能,手指触碰...而这个库能让有代码洁癖的你欢喜,不需要对库源码进行修改你就可以使用任何你喜欢的网络图片库进行配合。

    设计原则示例代码

    这些原则指导我们如何组织代码,使其遵循良好的结构和习惯。在这个“设计原则示例代码”压缩包中,我们可以期待找到与单一职责原则(SRP)、里氏替换原则(LSP)以及依赖注入原则(DI)相关的Java实现。下面将详细...

    RxBus-和EventBus完全一样

    因为rx完全可以替换掉eventbus所以导致了过多引入第三方jar包的问题,对于有代码洁癖和瘦身需求的同学们来说简直是一个噩耗; 如何在最大基础上修改我们已经存在的代码呢,那就是改造一个自己的rxbus,让他使用起来...

    洁癖_csdn

    【洁癖】这篇文章虽然标题和描述中并未直接提及IT知识,但从内容上看,可以关联到IT行业的某些方面,比如工作压力、生活与工作的平衡以及个人时间管理。在IT行业中,高强度的工作是常态,如文中主人公因为装修房子而...

    通过网页查看JS源码中汉字显示乱码的解决方法

    这种瑕疵对于有轻微强迫症+代码洁癖的人来说是不可容忍的 本来还以为是js文件没保存UTF-8格式,又把js文件重新保存了一遍 可惜,然并卵。。。 不过,最后还是被我找到原因了。 其实这个只是浏览器设置问题,下面以...

    WordPress 中冒号、endif、endwhile、endfor是什么?

    有代码洁癖的朋友可以使用这些语法,使代码更加整齐和易读。 2. 流程控制逻辑更清晰,代码更容易阅读。如果使用这些语法,代码将变得更易阅读和维护。 3. 一些从 ASP 等其他类 basic 语言家族转来的朋友,会更容易...

    基于HttpClient 4.3的可访问自签名HTTPS站点的新版工具类

    然而随着项目的升级和架构的调整,很多以前常用的类和方法都已被打上了@Deprecated注解,作为一个有代码洁癖的程序猿,我们也有必要升级一下工具类,让代码更加整洁。 另外在项目中正好需要访问https协议的接口,而...

    android循环滚动广告栏控件

    通用的广告栏控件,让你轻松实现广告头效果。支持无限循环,可以设置自动翻页和时间(而且非常智能,手指触碰...而这个库能让有代码洁癖的你欢喜,不需要对库源码进行修改你就可以使用任何你喜欢的网络图片库进行配合。

    android轮播

    通用的广告栏控件,让你轻松实现广告头效果。支持无限循环,可以设置自动翻页和时间(而且非常智能,手指触碰...而这个库能让有代码洁癖的你欢喜,不需要对库源码进行修改你就可以使用任何你喜欢的网络图片库进行配合。

    支持手机版的头像剪裁插件

    支持手机版的头像剪裁插件,纯H5和JS,使用copper插件。去除繁琐代码,保证是最简单的了。我有代码洁癖,并对所有外部引用都下载到本地了。

    pinyin4j-2.5.0.jar

    其实不影响项目的正常使用,但是对于有代码洁癖的人来说是不能忍的,看着难受,混淆文件proguard-rules.pro中也添加了 -ignorewarnings -dontwarn 但是没用,究其原因是因为jar包中有Android不能识别的类,后来自己...

    大学生常见心理问题的识别学习教案.pptx

    焦虑症表现为持续或突发的焦虑,可能伴有身体症状;强迫症则以强迫观念和行为为主,患者往往在强迫与反强迫之间挣扎;疑病症则表现为对健康状况过度担忧,尽管医学检查显示身体健康,患者仍然坚信自己患病。 以小刘...

    Android ViewPage广告轮播效果 源码

    Android-...而这个库能让有代码洁癖的你欢喜, 不需要对库源码进行修改你就可以使用任何你喜欢的网络图片库进行配合。 自定义你的Holder,实现更多复杂的界面,不一定是图片翻页,其他任何控件翻页亦可。

Global site tag (gtag.js) - Google Analytics