`

史上最烂的代码

阅读更多

其实本没有什么代码是“史上最烂”的,要有也只有“史上更烂”的,我想随便说说这个话题,也是源自豆瓣的一个讨论。事实上,系统复杂了被骂代码烂是一件司空见惯的事情。当然,也有一些短小的代码片段,就足以看出代码作者是个不怎么样的人。

布尔类型的使用是很容易变成最烂代码的:

1
2
3
if (isTrue())
    if (isTrue())
        doSomething();
1
2
3
if(boolVal == true) {
    .....
}

有一些毫无意义的注释:

1
return 1; // 返回 1
1
2
3
//如果标志为真,就返回true
if(flag)
    return true;

更无意义的是这样的变量命名:

1
2
public static final int ONE = 1;
public static final int TWO = 2;

也有人说,最烂的代码片段应该是这样的才对:

1
2
3
4
5
6
7
8
9
                                }
                            }
                        }
                    }
                }
            }
        }
    }
}

还有曾经被骂到遍体流脓的12306.cn,代码节选:

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
var sig = 0;
if(searchwordl.indexOf("'") > -1 || searchwordl.indexOf("\"") > -1 || searchwordl.indexOf("%") > -1 || searchwordl.indexOf("#") > -1 || searchwordl.indexOf("&") > -1 || searchwordl.indexOf("*") > -1 || searchwordl.indexOf("(") > -1 || searchwordl.indexOf(")") > -1 || searchwordl.indexOf("@") > -1 || searchwordl.indexOf("`") > -1 || searchwordl.indexOf("/") > -1 || searchwordl.indexOf("\\") > -1 || searchwordl.indexOf(",") > -1 || searchwordl.indexOf(".") > -1 || searchwordl.indexOf("=") > -1 || searchwordl.indexOf("<") > -1 || searchwordl.indexOf(">") > -1)
sig = 1;
 
searchwordl=searchwordl.replace("'",""); 
//searchwordl=searchwordl.replace(" ","");
searchwordl=searchwordl.replace("%","");
searchwordl=searchwordl.replace("#","");
searchwordl=searchwordl.replace("&","");
searchwordl=searchwordl.replace("*","");
searchwordl=searchwordl.replace("(","");
searchwordl=searchwordl.replace(")","");
searchwordl=searchwordl.replace("@","");
searchwordl=searchwordl.replace("`","");
searchwordl=searchwordl.replace("/","");
searchwordl=searchwordl.replace("\\","");
searchwordl=searchwordl.replace(",","");
searchwordl=searchwordl.replace(".","");
searchwordl=searchwordl.replace("=","");
searchwordl=searchwordl.replace("<","");
searchwordl=searchwordl.replace(">","");
if(searchwordl == '请输入搜索条件'){
    alert("请输入搜索条件");
    return false;
}
if(searchwordl == ''){
    alert("请正确输入搜索条件");
    return false;
}
if(sig == 1){
    alert("请正确输入搜索条件");
    return false;
}
document.getElementById('searchword').value=searchwordl;

还有JavaScript的烂代码,这实在太多了,就不贴了。越灵活的语言,越难驾驭,超级烂的代码就越容易见到。

Tiago Fernandez做过一个投票,选举最烂的Java API:

史上最烂的代码

公式是:score = (I can live with) + (Painful * 2) + (Crappy * 3) + (Hellish * 4)

结果,你猜到了吗?

史上最烂的代码

Java的框架多、语法严格,对于限制那些要来搞破坏的程序员确实有帮助。但是真要搞破坏,要限制还是限制不住。以前我接触过一个Portlet扩展类,一共好几千行,当时觉得这代码已经够烂了。可是后来我看到了5000多行的存储过程,还有7000多行的jsp页面——我以前以为Java程序员的破坏力要远远小于C/C++程序员。看来,也不尽然。

我的经历中接触到的烂代码,最常见的大概包括下面几种:

  • 一些命名的恶习,比如“cptct”这种缩略语缩略到几乎是密码电报的方法名,大概是受到Basic毒害,即便是早期的 Visual Basic 版本也在代码中强制实施了一些约束(如变量名的长度、模块中允许的变量数和模块的大小)。
  • 早些年的web项目(甚至包括现在的一些小公司做的web项目),不懂解耦、不会分层,逻辑全部揉在一起,一坨屎一样。页面模板直接访问数据库、样式代码散落在世界各地,HTML写死在各种逻辑里。
  • 在某些程序员眼里,“复用”==“继承”,只要有可复用的属性、公共的方法,就设法用无敌霹雳继承大法来解决,也不管适不适合,一级又一级,最后一定是一棵伟岸无边的继承树。
  • 无穷无尽的工具类。这类代码比继承大法的代码好不到哪去,XXHelper、XXTools这样的静态类满山遍地都是,但是复用的眼光倒是比只会继承多了一条路……
  • 不会用标准库函数、封装好的类库。我见过好几个这样的程序员,对于Integer、Long、Double这些数值对象类型的定义、方法几乎完全不了解,倒是对String很熟悉,所有的转换、校验,全部都转换成String以后完成,完成后再转回来。
  • 上帝类。本质是对类的职责单一不理解。用Java、C++的程序员写出上帝类也就罢了,今年我居然听朋友说到一个写Ruby的有相当工作经验程序员写出一个巨大的上帝类来……
  • 满大街乱跑的设计模式。本质是过度设计。好好一个“new Template()”非要引入工厂,再搞一个策略模式、模板模式,不过瘾,最后加上注解来实现……
  • 大部分的JavaScript、CSS。不解释。

今天有同事说,代码之所以成为烂代码,很大可能是写代码的人会遇到比后来读代码的人多得多的问题,虽然写代码的人解决了大部分的问题,但是剩下的问题还是足以让代码遗臭万年。不过我不这么看,我看到过年份比较早的VB代码、还有Delphi代码,虽然都是界面开发用的,虽然很多理念远远不及今天,代码依然清晰易懂。

有的程序员说,工期紧、项目重,领导催得我天天吐血,迫不得已我写出了烂代码。客观原因千千万万,我确实无话可说,毕竟在物质文明还非常虚弱的时候,还是不要扯精神文明的蛋。但是,优秀的程序员是有追求的,而人是会麻木的,总是把项目压力挂在嘴边的,给一个宽松的限期也不见得能如何。

还有的程序员说,唯物辩证法告诉我们,任何事物都有两面性,所以我们要学习烂代码中好的设计,并且把糟糕的设计引以为戒……我说,得了吧。烂就是烂,把屎放在冰激凌蛋筒里也还是屎,那么矫情干什么?

有很多程序员总有一种推倒重来的冲动,特别是看到烂代码的时候。我也曾经如此。其实这是危险的。况且在很多情况下你的重写未必有他原来的烂代码好。也许你能解决其中的30个问题,却引入了50个新问题。重构还是要在业务模型和流程清晰的情况下尽量小改动、划模块入手,大开大合总是危险的。

总说十五年前吃过多少多少苦的程序员我一点都不佩服,我佩服的是在十五年前那种条件和观念下,依然能够写出现在看来都让人无比舒坦代码的优秀程序员。不写烂代码就是爱惜生命、节约资源、保护地球,写好的代码就是一个程序员的素质,没有那么多理由可以讲。

文章系本人原创,转载请注明作者和出处(http://www.raychase.net

注:本博客已经迁移到个人站点 http://www.raychase.net/ ,欢迎大家访问收藏,本ITEye博客在数日后将不再更新。

1
0
分享到:
评论
4 楼 youarestupid 2012-11-10  
**Tools、**Utils、**Helper这类工具类,比直接在类里面随便写工具方法强多了,哪些用到什么功能就随手在当前类中写个静态方法的做法才是低级的开发方式,那样做完全谈不上什么代码复用,纯粹是重复劳动无用功。
3 楼 zui4yi1 2012-11-09  
初学者写的东西,很多还是自学成才的人初写的代码,当然烂了
2 楼 muyishuihan 2012-11-09  
楼主言辞有些犀利,不十分赞同
1 楼 zhangzhaoaaa 2012-11-09  
楼主能否贴一些好的代码样例呢?

相关推荐

    史上最牛代码

    ### 史上最牛代码解析 #### 概述 标题与描述均为“史上最牛代码”,这一表述虽然简单,但是蕴含了对于某段程序代码的高度评价。通常,“最牛”这样的词汇意味着这段代码在某些方面达到了极致,无论是从技术难度、...

    史上最好上传代码及jar包

    本文将深入探讨“史上最好上传代码及jar包”这一资源中所涉及的关键知识点,包括JSP文件上传、Java文件上传以及jar包的使用。 首先,JSP(JavaServer Pages)是一种动态网页技术,它允许开发人员在HTML页面中嵌入...

    史上最牛逼的俄罗斯方块源代码

    《史上最牛逼的俄罗斯方块源代码》这个标题暗示了我们即将探讨的是一个非常出色的、具有里程碑意义的俄罗斯方块游戏的源代码。俄罗斯方块作为一款经典的游戏,其源代码解析将涉及到许多编程和游戏设计的核心概念。...

    史上最牛的程序——几行代码 3d效果

    这是国外某编程大赛第一名的程序,短短的代码行,看似像是机器代码 程序的运行结果是3d动画,很牛的程序! 程序运行时在运行里敲入cmd进入dos界面 然后进入该文本所在文件夹 然后键入debug 然后你就慢慢等待 奇迹的...

    史上最全的转贴代码

    【标题】:“史上最全的转贴代码”通常指的是一个包含大量可复用代码片段或解决方案的集合,这些代码可能来自于各种编程语言,旨在帮助开发者快速解决问题或者作为学习参考。这样的资源对于初学者和经验丰富的程序员...

    hqu嵌入式课设stm32-基于stm32f103zet(正点原子精英版)的交通信号灯

    题目——交通信号灯 如下: (1)主辅路控制(基础部分) 在一条主路和一条辅路交汇的十字路口,主路和辅路上均设置红、绿两色信号灯,分别代表车辆禁止通行、允许通行。...注意:代码压缩包内为史上最烂代码,不可全抄

    C# 史上最NB的代码

    C# 史上最NB的代码 string value = dateTimePicker1.Text.Replace('年', '-').Replace('月', '-');

    史上最全js代码(100个)

    这个名为"史上最全js代码(100个)"的资源集合,显然是一份全面的JavaScript代码示例库,涵盖了广告、新闻、动画、菜单、相册、幻灯片等多种应用场景,对于学习和提升JavaScript技能非常有帮助。 1. **广告**:在网页...

    史上最强悍的二维码应用源代码

    本资源“史上最强悍的二维码应用源代码”提供了一套全面且强大的二维码应用开发解决方案,适用于Android平台。 源代码分析: 1. **Android平台开发**:这套源代码是基于Android操作系统开发的,这意味着它利用了...

    史上记事本源代码金华

    "史上记事本源代码金华"是一个聚焦于记事本应用程序源代码的项目,它包含了开发者精心编写的代码,旨在提供一个功能完善的文本编辑工具。这个项目被标签为"实际",意味着它不仅是一个理论概念,而是具有实际应用价值...

    成都源代码教育之史上最权威PHP入门教程详解

    成都源代码教育之史上最权威PHP入门教程详解 成都源代码教育之史上最权威PHP入门教程详解 成都源代码教育之史上最权威PHP入门教程详解 下载有问题请联系我!

    史上最详细的扩展List控件制作代码

    涉及到的源代码文件,如`LzqListEx.cpp`、`LzqListExDlg.cpp`、`MsgHook.cpp`等,分别处理主程序逻辑、对话框类实现、消息钩子处理等。`LzqListEx.aps`是工程文件,`ListCtrlEx.cpp`和`ListCtrlEx.h`包含了List控件...

    史上最经典C语言源代码

    《史上最经典C语言源代码》是一本集合了200个案例教程的宝贵教材,旨在帮助初学者和有经验的程序员提升对C语言的理解和应用能力。C语言,作为计算机科学的基础,是许多现代编程语言的基石,其简洁、高效的特点使得它...

    史上最全Hbuilder 代码片段snippets,支持Thinkphp

    这个“史上最全Hbuilder代码片段snippets”集合是针对ThinkPHP框架的,旨在帮助开发者快速编写和实现HTML、CSS、JavaScript、jQuery以及ThinkPHP的常见代码结构。 1. **Hbuilder代码片段(Snippets)**: HBuilder...

    史上最全的行业代码.pdf

    史上最全的行业代码.pdf

    androidstudio 史上最全快捷键 代码提示 重命名快捷键

    androidstudio 史上最全快捷键 代码提示 重命名快捷键,包括100+ 条快捷键,采用txt文件形式,方便使用时查找快捷键,提高码代码的速度就靠它了

    史上最简单的SpringMVC代码

    在这个史上最简单的SpringMVC代码示例中,我们将深入理解其基本概念和配置。 首先,MVC模式是一种将业务逻辑、数据和用户界面分离的设计模式。Model代表应用的数据模型,View负责展示数据,而Controller接收用户的...

    10分钟通晓指针,史上最全的指针讲解

    这篇文章《10分钟通晓指针,史上最全的指针讲解》将带你全面了解指针的各个方面,帮助你迅速掌握这个关键技能。 首先,我们要明白指针的本质。在计算机内存中,每个数据都有一个唯一的地址,指针就是一个存储该地址...

Global site tag (gtag.js) - Google Analytics