Redian新闻
>
接手前同事代码,我差点吐了

接手前同事代码,我差点吐了

科技

你好,我是yes。

年前公司优化了一些人,最近我开始接手他们的项目。

然后...我就麻了。

一开始接到这个任务的时候,我没怎么当回事儿,根据一些需求评估的时间也比较紧凑。

后面越看越不对劲,估时两天的开发,我每天加班都硬生生的花了 5 天。

绝大部分业务实现就是直接干,硬怼!

没有抽象,没上缓存,没有批处理的概念循环一个一个调,有些方法也没有事务,更别说补偿。

一个方法多的有七八百行,平铺直叙。

上传图片、创建订单等等操作一个方法里面同步直接干,超不超时就随缘。

把我都看傻了,也得亏这个项目是新项目,当前没什么用户,不然真有用户大量使用这方法不报错我直播倒立洗头。

鉴赏下

业务或者性能方面不说了,因为就连编码风格或者说基础可能还不如实习生(我们公司都是招5年以上的)。

我截了几处,一起来来鉴赏下:

都是公司代码,所以打码

先来个开胃菜,热热场子:

这样的代码很正常,有些人写 demo 会输出到控制台,但是对应生产项目里面在 main 分支我看到很多这样的代码,这就有点说不过去了。

就算习惯用这种方式调试,一两个可以说忘了删了,但是遍地都是说明压根就没想删除。

对自身提交代码的要求太低了。(合并分支的同学也得背点责任)

趁热打铁,我们再来看下这段代码:

JSONObject 本身就实现了 Map 接口,内部也是个 map:

也就是说 JSONObject 本身就可以通过 key 去 get value,何必再变成个 map 执行一样的操作,em....。

上述的代码可以说其实影响不大,接下来的代码就有点东西了!

来看看这个 sleep:

首先看下这个方法的上面标记了 @Async 说明这是一个异步方法,那为什么要 Thread.sleep(300)?

起初我也没看明白,后来发现了这个异步的方法里面需要修改前面主方法新增的一个数据库数据,所以这里  Thread.sleep(300) 的目的就是等待主线程的事务提交,不然异步方法就取不到数据了。

我称这个为玄学编程,就是拿 300 毫秒赌主线程的事务已经提交,提交了好说,正常执行异步的逻辑。

要是没提交?那就....爱咋咋了。

既然说到  @Async 了,那继续看这个项目里的另一个  @Async  使用,我称之为假想异步

可以看到声明了一个 createWxxx 方法,使用 @Async,很明显编码者想异步执行这个方法里面的内容。

然后我查看这个方法的引用,发现全局只在同个类里面的另一个方法使用

就是个类的本地方法调用。

我们都知道在 Spring 里面,不论是事务注解还是异步注解,通通都是依靠 AOP 注入逻辑的,而本地方法调用是走不了代理的,所以这里的 @Async 压根就没生效,所以说这叫假想异步:只要我加了 @Async 我就异步啦!(还指定了线程池)

最后们再看一个分布式锁的操作。

我先给你点时间仔细看看下方的代码是否有问题。

其实一开始我都没发现,后面定睛一看,我滴妈加解锁的 key 都不一样,可以看到加锁的 key 比解锁的 key 多个 dto.getOrderNo()....

ok,没问题,这可以认为是疏忽,谁都有疏忽的时候。

但是分布式锁是这样用的??

 if (redis.setNx(xxx)) {
    //抢到锁了,dosth
 } 
 finally {
   redis.del(xxx) ???
 }

如果抢到锁就执行后面逻辑,这个没毛病,但是 finally 里面直接就删除锁是个什么意思??

合着抢不到锁,也直接把别人的锁给删了

这还加什么锁呢?

这压根就是个大坑,坑的后面的人可能需要疯狂修数据!

最后

哎,还有很多神操作,比如 for 循环 RPC 调用外面还套了个事务。。真的都是大改!

其实很多时候公司压根不需要什么多牛的程序员。

基础踏实,稍微有点代码追求的程序员在大部分情况下比大牛都重要多了,毕竟一个项目绝大部分代码都是普通程序员写的,如果这里一点坑那里一点坑,加起来就是屎山,坑的就是公司和后人。

不说了,继续去修bug了,如果后续有更夸张的操作,我会及时更新的,哈哈哈。

对了,我最新一期的个人VIP专属问答已经启动了,已经给很多小伙伴修改了简历和回答面试问题,有几个已经找到工作啦!

还有之前小伙伴的“感谢信”,让我觉得我的做法很有意义!

问答详情,可以看我的这篇介绍我的VIP问答服务,或者看公众号的次条。还有5个名额,多的我答不过来后面都不接的!

我是yes,我们下篇见~

微信扫码关注该文公众号作者

戳这里提交新闻线索和高质量文章给我们。
相关阅读
2030年加拿大减排目标与预测夺命 Redis,我差点就没抗住!“我差点被活埋!”澳女花光积蓄买梦中情屋,结果房子塌出巨型天坑悉尼中餐馆吃出“油炸蟑螂”,华男恶心“差点吐店里”!老板道歉免单却不认脏,“可能是菜里带来的”离职去摆摊的大厂人,薪资碾压前同事龙泉寺的一段往事“色情上瘾,让我差点成为迷奸的帮凶”来自外太空的计算错误:宇宙射线干扰了我的心脏起搏器,我差点因此丧命买下私密成人物品后,要求商家保密发货,收到后我差点气疯啊哈哈哈哈哈“我差点被骗100万”!卷入“国际大型洗钱案”,留学生为何频成诈骗首选……为啥你的前同事降薪一万,下楼当保安?Costco春节上新! 华人:看完我差点儿被送走接手前同事代码,特别烂,各种BUG,看麻了。。。第二次徒步圣路,750公里葡萄牙之路+英国之路:D29~率先告捷窃取开源代码,还拉黑质疑者,这家 AI 公司试图删除代码了事惊动了拜登!23岁男子在银行枪杀5名前同事,还直播全过程,曾留言“想杀死银行里的所有人”我差点赶不上飞机救命!导师被气到差点吐血,师弟直呼:太惨了……高喊4000点的美女分析师“揭丑”前同事:涉推接盘票、桃色事件,“嫉妒我,让我失业一年多”!对方回应:诽谤,已报警终于回到家,我差点不认识了我差点成为这位浙大女硕士的猎物......绝美挪威荷兰夏日之旅(一)哈当厄尔高原-沃尔令斯大瀑布首测丨100万的新款特斯拉,快得我差点吐了。带着5部旗舰机去环球影城,我差点被打因为用了Google地图,我差点被美军击毙……PS5要出哈里和梅根为主角的游戏了!!等等,我差点忘了今天日期……Costco春节上新! 纽约华人:看完我差点儿被送走我差点送命...这样写代码,同事乐开花!“女儿进了全市最好的高中,她小男友一番话,我差点哭晕过去……”跟着网红学做泡面鸡蛋羹,我差点把家烧了新来了个同事,代码命名规范是真优雅呀!代码如诗!!单身,该不该让假?澳女吐槽:前同事有娃,找领导逼我让出复活节假期学完书本科学知识需上劳动大学“我差点死在缅甸”
logo
联系我们隐私协议©2024 redian.news
Redian新闻
Redian.news刊载任何文章,不代表同意其说法或描述,仅为提供更多信息,也不构成任何建议。文章信息的合法性及真实性由其作者负责,与Redian.news及其运营公司无关。欢迎投稿,如发现稿件侵权,或作者不愿在本网发表文章,请版权拥有者通知本网处理。