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

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

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

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

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

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

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

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

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

……

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

但是,这样真的好吗?

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

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

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

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

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

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

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


相关文章
|
定位技术 数据格式
MIKE 21 教程 1.5 基于卫星影像绘制河道边界
MIKE 21 教程 1.5 基于卫星影像绘制河道边界
|
6月前
|
存储 人工智能 资源调度
MCP协议深度集成:生产级研究助手架构蓝图
本文详解基于LangGraph与MCP协议构建研究助手的技术方案,涵盖双服务器集成、状态化智能体设计与用户元命令控制,助你掌握生产级代理系统开发要点。
546 1
|
机器学习/深度学习 编解码 算法
《深度剖析:生成对抗网络如何实现图像风格的细腻逼真迁移》
生成对抗网络(GAN)在图像风格迁移中展现出巨大潜力。GAN由生成器和判别器组成,通过对抗训练生成逼真图像。相比传统方法,GAN能自动学习深层特征,生成多样化、细腻的风格,并实现高效处理。关键技术如多尺度训练、注意力机制及损失函数优化进一步提升了效果。GAN已广泛应用于艺术创作、游戏开发和影视制作等领域,未来有望带来更多创新应用。
460 2
|
存储 缓存 前端开发
前端快照实现方案详解
前端快照实现方案详解
1089 1
|
开发工具 git Windows
Git | 向GitHub提交代码超时处理
向GitHub提交代码超时处理
939 0
|
设计模式 数据库
理论篇|如何避免写出面条代码
理论篇|如何避免写出面条代码
330 0
理论篇|如何避免写出面条代码
|
存储 关系型数据库 MySQL
MySQL 中单表数据的最大行数应该控制在多少?
MySQL 中单表数据的最大行数应该控制在多少?
3683 1
MySQL 中单表数据的最大行数应该控制在多少?
|
传感器
水传感器的技术原理有哪些
水传感器通过多种技术原理检测水质,包括电导率测量、光学感应、化学反应和生物传感等方法,可监测pH值、溶解氧、浊度等参数。
|
JSON 数据可视化 JavaScript
低代码可视化-uniapp响应式数据data-代码生成器
低代码可视化-uniapp响应式数据data-代码生成器
305 0
|
机器学习/深度学习 人工智能 监控
如何评估AI教育效果?
【6月更文挑战第1天】如何评估AI教育效果?
1538 3