公司的java项目是如何一步步变烂的?

作者:cndz 围观群众:754 更新于 标签:

首先先说,你去一家公司就职,很有可能会发现公司的项目就像一个垃圾场,各种恶心的代码堆在一起。之前对公司的产品充满各种幻想,但现在幻想破灭了。你要做的事情,就是去维护这些老项目。你一直在疑惑,为什么项目的代码这么烂。各种if else嵌套,也几乎看不到任何设计模式。随便翻看几个类,就能看到大量的空指针隐患。

终于有一天,有一个新项目下来,老板任命你是负责人,于是你在心中窃喜,终于可以证明自己了。我一定要让代码显得优雅,跟烂代码说再见。前几天各种顺利,你用了很多设计模式,也知道用抽象类来做业务抽象,方便系统扩展。你越做越有劲,感觉自己真是个小天才。

由于项目是多人合作的,随着项目的迭代,很多新人开始不按照你的架构来开发代码。原本应该老老实实继承你设计的抽象类,可是别人为了图方便,毫不犹豫地在controller里面加一个else if,你看完后几乎要炸毛。赶紧重构!但是,项目已经上线了, 运营了,光是生产数据就有好几十万。老板问你,你有把握吗?你敢动吗?你陷入了沉思,最终没敢在项目上大动干戈,然后反手也加了一个else if。慢慢地,有的新人甚至都不用你设计的通用dao,而是自己在service里面写起了jdbc…

因为需求一直在做,原始的精美设计开始变得越来越臃肿,逻辑变得复杂无比。没有人敢去重构,也确实不可能重构了。终于,你接受了这个事实。有一天,你逮住一个在service里面写jdbc的新人,质问他为什么不按照规范来写?新人一脸无辜,这个项目又没有开发手册,就连个像样的业务文档都没有,我哪知道什么代码该写在哪里啊?也是,这是一个n手的项目,完全精通系统的人已经没有了,老员工一个个地辞职,懂业务的人也几乎没有了。每个新人都无比痛苦,只能靠搜代码来反推业务逻辑,能完成任务已经不错,也就别提代码是不是优雅了。

虽然知道了这个项目的弊病,但是你也懒得去整理项目的开发文档,因为你知道就算整理了,老板也不会给你涨工资,多一事不如少一事。后来,你也辞职了,准备去下一个公司,继续去面对一个讨人厌的老项目。