故意把代码写得很烂,这样的 “防御性编程“ 可取吗?

简介: 故意把代码写得很烂,这样的 “防御性编程“ 可取吗?

传统意义的 “防御性编程” 是说采取一些预防措施来确保代码的稳健性和可靠性,

最近两年,网上讨论 “防御性编程” 的声音多了很多,

但是这里大家讨论的 “防御性编程” 可不是传统意义上的概念,

简单地说,就是写一些 “别人看不懂,只有自己能看懂,甚至自己也看不懂,只有机器能懂” 的代码。

大家的想法大概是这样的:如果哪天自己被裁了,公司也难以快速搞懂这些代码,相当于留了个 “后手”。

说到怎么实现这个 “防御性编程” ,很多互联网大厂员工也开始纷纷 “整活”,提出了各种防御性编程的 “奇思妙想”,比如:

  • 就算是最简单的业务逻辑,也要往复杂里写,最好别人都看不懂
  • 能多用几个设计模式就多用几个设计模式,不能用也要创造条件用,把代码结构搞得越难以理解越难以维护越好
  • 一个方法能搞定的,坚决不写第二个,把所有的业务逻辑都写到一个方法,最好写个几百行,让谁都不敢改
  • 条件语句也要多用几层,一层嵌套一层,把它做成迷宫最好,让老鼠进来也要晕头转向
  • 变量和方法命名时最好使用无意义的字母组合,代码的可读性越差越好,也不要写注释,有本事你们自己读懂

……

如果真的按这些 “奇思妙想” 写代码,不光别人看不懂,恐怕过个三两月,估计作者自己也看不懂了,真的就只有计算机才能看懂了!

但是,这样真的好吗?

虽然有很多人拍手称好,我倒是觉得这样对于程序员来说,是弊大于利的,理由如下:

首先,这样做违背职业道德,损害了程序员自身的职业声誉。程序 员的立身之本不是技术,而是信誉,软件开发的圈子说小不小,说大其实也没那么大,如果你的声誉不好,未来的发展肯定走不远,没必要为了一口饭而丢掉自己的信誉。

其次,故意编写难以理解的代码,不利于个人技能的成长。代码的魅力在于重构,在重构的过程中,你一遍遍地优化代码,你就有动力去学习更多更好的技术,慢慢地,掌握的技术就会融汇贯通,最终代码变得优雅,性能变得高效,你也成为一个人人称颂的技术大牛。反而,如果你总是将心思放在如何把代码写得更 “烂”,你就没有动力去学习,这样你就不会有成长,也许你会说,你会私下学习新技术,但如果新技术不真正应用在真实项目里,永远都不会变成你自己的技术!

再次,故意编写难以理解的代码,反而可能会让你更快地丢掉 “饭碗”,因为质量差的代码肯定会导致团队效率降低,出错的机率也更大,这样会更打击团队的士气,这样的产品客户也不愿意用,这样的情况不是更容易让老板坚定裁员的决心吗?

最后,做过企业的老杨更清楚,当一个企业效益不好的时候,为了自保,往往都是整个部门整条业务线裁掉,你把自己 “包装” 得再难以替代都是无济于事的,所以,把心思花在如果把代码写 “烂” 上,真的是一件性价比很低的活,不如把这个时间用来好好提高自己的能力!

总而言之,程序员搞防御性编程固然可以理解,现在确实有一些企业做得很不好,比如变相裁员、无征兆裁员、想方设法不给赔偿等等,伤害了程序员的心,但这样子做,短期来看,是程序员和企业的互相伤害;长期来看,对程序员自身的伤害更大!因此,我觉得程序员最好在上班的时间还是一门心思地提高自己,写出可靠的代码,这样既对得起自己的职业良知,也提高了自己,何乐而不为,只要自身水平高,真的被裁员了也不怕,拿一笔赔偿到别的企业上班,不是更香吗?哈哈…… 你觉得有道理吗?欢迎留言讨论!

我是老杨,一个执着于编程乐趣、至今奋斗在一线的 10年+ 资深研发老鸟,是软件项目管理师,也是快乐的程序猿,持续分享全栈实用编程技巧、项目管理经验和职场成长心得。欢迎关注老杨的公众号,相互交流,共同进步!


目录
打赏
0
3
3
0
37
分享
相关文章
还没适配 Android 12 的要抓紧了(下)
还没适配 Android 12 的要抓紧了(下)
2000 0
还没适配 Android 12 的要抓紧了(下)
Oracle 分区表的新增、修改、删除、合并。普通表转分区表方法
一. 分区表理论知识 Oracle提供了分区技术以支持VLDB(Very Large DataBase)。分区表通过对分区列的判断,把分区列不同的记录,放到不同的分区中。分区完全对应用透明。 Oracle的分区表可以包括多个分区,每个分区都是一个独立的段(SEGMENT),可以存放到不同的表空间中。
1466 0
理论篇|如何避免写出面条代码
理论篇|如何避免写出面条代码
242 0
理论篇|如何避免写出面条代码
uniapp是什么?用uniapp开发好不好用?
UniApp 是一种基于 Vue.js 框架的跨平台开发框架。它可以允许开发者使用一套代码,同时在 iOS、Android、H5、小程序等多个平台上构建应用程序。UniApp 的设计理念是 “一套代码,到处运行”,它提供了一种高度封装的开发模式,使得开发者可以快速地开发并发布应用程序。
324 0
在Docker中,镜像内没有curl,kill,ipconfig等指令如何添加?
在Docker中,镜像内没有curl,kill,ipconfig等指令如何添加?
一文帮你搞定MyBatis的类型转换模块,深度好文,欢迎一键三连!!!
MyBatis是一个持久层框架ORM框架,实现数据库中数据和Java对象中的属性的双向映射,那么不可避免的就会碰到类型转换的问题,在PreparedStatement为SQL语句绑定参数时,需要从Java类型转换为JDBC类型,而从结果集中获取数据时,则需要从JDBC类型转换为Java类型,所以我们来看下在MyBatis中是如何实现类型的转换的。
一文帮你搞定MyBatis的类型转换模块,深度好文,欢迎一键三连!!!
使用easyPOI时碰到的几个问题(记录一下)
前面我们说了如何使用easyPOI,详情请参考全网最全最简单使用easypoi导入导出Excel的操作手册,今天我来记录下在使用easyPOI时碰到的几个问题,本来以为上传下载功能使用EasyPOI之后挺简单的,结果翻车了,一个上传和下载就因为版本的问题搞了老半天。真的是很愁人呀。下面就是我系统的初始环境。
1189 0
使用easyPOI时碰到的几个问题(记录一下)
AI助理

你好,我是AI助理

可以解答问题、推荐解决方案等

登录插画

登录以查看您的控制台资源

管理云资源
状态一览
快捷访问