防御性编程,真的可以防止被裁吗?

你好,我是猿java

最近,写了一篇 改善代码质量,试试这10种方法 的文章后,很多小伙伴私信,让我了解下防御性编程,于是,就着此机会聊一聊这个梗。

1. 背景

疫情之后,大环境一直很低迷,互联网也未幸免,于是,很多公司相继"开节流",可怜的程序猿惶恐不安...

接着,戏剧性的一幕发生了,国内的互联网大厂相继出现"降本见"的名场面,首先暴雷的是阿里云,事故原因:底层服务组件故障...

接着,滴滴崩了,事故原因:k8s升级导致...

接着,腾讯云也崩不住了,事故原因:技术故障...

对于老东家出现的线上事故,个人还是感觉挺惋惜的,很多同行的年终奖可能直接或者间接的受到了影响,尽管,事故官方都给出了相应的回复和歉意,但是,事故对用户的伤害以及对公司本身的损失,远不亚于"节流"的总额。

于是,很多人开始调侃"干活的人裁得太多了,都是老板造成的"。做技术的都清楚,服务器的稳定性不可能达到100%这种理想状态,因此,调侃固然有戏虐,但不乏真实性,很多技术岗位平时看起来并不起眼,关键时刻就能体现出他们的价值,而这个"关键时刻"的代价有时候会比较大。

最后,防御性编程一语双关的梗就润物细无声地传遍了各大技术论坛和网站...

2. 什么是防御性编程?

防御性编程是什么?它主要是用来做什么的?先来看看维基百科的解释:

通过维基百科的解释可以看到:防御性编程原本是指为了代码和系统的安全,特意在代码中增加了一些提升代码质量的保证,比如:参数校验,安全校验等等。

3. 一语双关

而特定环境下,防御性编程就出现了另一层含义:报复性编程,为了防止被裁,代码被动了手脚,只有本人才能维护。

防御性编程,绝大部分是客观产生的,比如代码中出现的 bug,但也存在着主观性,常见的一些方式有:

  1. 代码不加注释

  2. 命名直接使用a,b,c等等毫无含义的变量,大大增加了代码维护的难度;

  3. 代码结构被破坏,函数直接随意的相互调用,极大的破坏高内聚低耦合;

  4. 代码预留后门;

  5. ...

4. 如何看待?

"防御性编程",真的可以防止被裁吗?

首先,裁员是公司管理层和资本综合考量的结果,非打工人可以左右。

其次,员工和企业,员工属于弱势群体,经济社会,假如不幸被裁,如果企业给出了合理的赔偿那也无可厚非,如果没有获取合理赔偿,作为员工,完全可以采用法律手段来保护自己;

再次,作为技术人员,一定要有自己的职业操守,千万不要违法乱纪,主观性的"防御性编程",轻则造成线上事故,对公司造成经济损失,重则违法,切莫踩红线。

最后,打铁还需自身硬,僧(程序员)多粥(就业机会)少的时代,作为技术人,更多的是想办法提升自己的竞争力,转"防御性编程" 为 防御性学习,就算某天中招被裁,只要技术能力过硬,也一定能再找到一份好工作。

最后,把猿哥的座右铭送给你: 投资自己才是最大的财富。 由于水平有限,如果文章存在缺点和错误,欢迎批评指正。

相关推荐
luckdewei11 分钟前
那个用 passlib 做认证的新同事,上线第一天就把用户密码写进了日志
后端
ping某1 小时前
为什么 Nginx 明明监听了 80,转发后端时却用了 4xxxx 端口?
后端·nginx
JustHappy2 小时前
我汇总了身边朋友的经历才发现,其实第一份实习是最难找的......
前端·后端·面试
uhakadotcom2 小时前
在python 的 工程化架构中 ,什么是 薄包装器层?
后端·面试·github
唐青枫6 小时前
Java JDBC 实战指南:从 Connection 到事务和连接池
java
用户1474853079746 小时前
CodeX使用Skill生成游戏美术和音乐资源,一分钟入门
后端
Melody1236 小时前
用 abort 中断 AI 流式请求,我之前做错了
后端
onething3657 小时前
Spring Boot + Spring AI 从入门到实战:7天转型计划 Day 5 —— SSE 流式输出 + 打字机效果
人工智能·后端·全栈
一个做软件开发的牛马7 小时前
MyBatis-Plus 从零实战:完整搭建可运行 Demo,BaseMapper 零 SQL、Wrapper 条件构造、分页插件与代码生成器详解
java·后端
用户3721574261357 小时前
Java 处理 PDF 图片:提取 PDF 中的图片,并压缩 PDF 图片体积
java