关于重构一点简单想法

关于重构一点简单想法

当前工作的组内,由于业务开启的时间正好处于集团php-》go技术栈全面迁移的时间点,组内语言技术栈存在:php、go两套。

因此需求开发过程中通常要考虑两套技术栈的逻辑,一些基础的逻辑也没有办法复用。

在这样的背景下,技术栈从php迁移到go这样的重构是一个时不时就会提起的话题。

为什么要重构

一言以蔽之:提高项目后续维护/开发的效率。

随着项目的持续开发,项目复杂度会越来越高,开发效率会越来越低,如下图,而且不仅开发效率越来越低,出bug的概率也越来越大。我们重构的目的就是让图中的的黑色曲线的斜率平缓一些。

我们要明白 重构(refactor) != 重写(rewrite),重写是重构的一个子集,每一次对代码质量提升而产生的修改都可以称之为重构,小到一个函数或者变量的改名。

实践向:怎么进行重构

这里不高谈阔论一些战略,从战术角度来讲述一些方法论。

平时|小型重构
  1. 重构无论大小,看见能顺手重构的地方就及时顺手重构。这里列出来一些常见的可以顺手重构的地方:

    1. 函数更改更合适的名字
    2. 不同逻辑收敛到一个地方统一处理(抽象),比如:不同地方的同样功能的函数,公共枚举值。
    3. 将"巨型"函数拆成合适的小函数
  2. 开发过程中就分配时间进行重构:如果不是特别紧急的需求,建议预留10%~20%的时间留给重构工作。

专项大型重构

当项目的架构对开发效率造成了严重的阻碍,此时可以考虑一个专项对项目专门排期进行重构。

  1. 对重构的顺序按照下面等级排序:(优先考虑价值、其次考虑成本)。
  1. OKR管理,指定好目标:1.现状整理(到底有哪些技术债);2.制定好具体目标:收敛哪几个功能能力,收敛配置统一到某个地方等等;3.人员分配和排期。

题外话|荒唐走板

  1. 写代码的时候注意保护好自己:无论是哪种重构,只要对代码运行可能造成隐患的,都建议通知对应功能的负责人,让其对代码的修改进行cr等工作,防范重构引入的风险。
  2. 重构不是目的,只是手段:重构代码的目的是为了提高代码质量,提升团队的开发效率。在平时的工作中,团队最好达成共识,一起对代码质量做好监控相关的工作。
相关推荐
孟陬8 小时前
国外技术周刊 #1:Paul Graham 重新分享最受欢迎的文章《创作者的品味》、本周被划线最多 YouTube《如何在 19 分钟内学会 AI》、为何我不
java·前端·后端
树獭叔叔8 小时前
13-KV Cache与位置编码表:大模型推理加速的核心技术
后端·aigc·openai
想用offer打牌8 小时前
一站式了解四种限流算法
java·后端·go
嘻哈baby8 小时前
用 C++ 写线程池是怎样一种体验?
后端
嘻哈baby8 小时前
SQL Server 和 Oracle 以及 MySQL 有哪些区别?
后端
绝无仅有8 小时前
Redis过期删除与内存淘汰策略详解
后端·面试·架构
武子康8 小时前
大数据-237 离线数仓 - Hive 广告业务实战:ODS→DWD 事件解析、广告明细与转化分析落地
大数据·后端·apache hive
绝无仅有8 小时前
Redis大Key问题排查与解决方案全解析
后端·面试·架构
舒一笑8 小时前
Ubuntu系统安装CodeX出现问题
linux·后端
golang学习记9 小时前
GitLens 十大神技:彻底改变你在 VS Code 中的 Git 工作流
前端·后端·visual studio code