持续更新中|关于重构的一点简单的思考

持续更新中|关于重构的一点简单的思考

当前工作的组内,由于业务开启的时间正好处于集团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. 重构不是目的,只是手段:重构代码的目的是为了提高代码质量,提升团队的开发效率。在平时的工作中,团队最好达成共识,一起对代码质量做好监控相关的工作。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.hqwc.cn/news/864416.html

如若内容造成侵权/违法违规/事实不符,请联系编程知识网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

20241316 《计算机基础与程序设计》课程总结

20241316 《计算机基础与程序设计》课程总结第一周作业:浏览教材并提出问题第二周作业: 自学教材计算机科学概论(第七版)第1章并完成云班课测试 《C语言程序设计》第1章并完成云班课测试第三周作业:计算机科学概论(第七版)第2章,第3章 并完成云班课测试第四周作业:学习…

Windows环境下反弹shell各类姿势

在渗透测试过程中我们有时候需要通过Windows平台来反弹shell到我们的VPS主机以及CS端,那么这个过程中我们就需要借助Windows平台内置的可执行程序来执行命令,其中首选的就是powershell,本篇文章我们主要介绍如何通过Windows平台中如何通过powershell来反弹shell操作。 power…

集成运算放大器的简单介绍

集成运算放大器是一种具有很高放大倍数的多级直接耦合放大电路。是发展最早、应用最广泛的一种模拟电路。 集成电路是把整个电路的各个元件以及相互之间的连接同时制造在一块半导体芯片上,组成一个不可分点整体。 集成电路的特点:体积小,重量轻、功耗低、可靠性高、成本低、…

利用huggingface尝试的第一个简单的文本分类任务

` 这是一个简单的文本分类任务,基本的流程步骤还是挺清晰完整的,和之前那个简单的cnn差不多, 用到了transformers包,还需用到huggingface的模型rbt3, 但是好像连接不上``遇到的问题: 1.导入的包不可用,从AutoModelForTokenClassification换成了AutoModelForSequenceC…

【嵌入式编程】内存分布

一、内存分布图在操作系统中,内存被组织和管理以支持进程的运行。以下是一些常见的内存分布概念: 【内核空间】:操作系统内核使用的内存区域,用于存储内核代码、数据结构和进程控制块(PCB)。【用户空间】:存储用户的代码。未初始化变量区(.bss):存放未初始化的全局变量…

北京健康证(立水桥地铁站附近)

体检:记得带身份证就可以,最好自带一支笔,用他的笔要排队,我买的是96的,带培训证的。 下面这个表只填:身份证号,手机号,姓名就可以,类别、是否培训以交钱时候前台登记的为准,照片也不采集,直接用身份证上的相片

北京健康证

体检:记得带身份证就可以,我买的是96的,带培训证的。 下面这个表只填:身份证号,手机号,姓名就可以,类别以交钱时候前台登记的为准,照片也不采集,直接用身份证上的相片

anaconda安装与环境配置

一、Anaconda简介 ​ Anaconda 是专门为了方便使用 Python 进行数据科学研究而建立的一组软件包,涵盖了数据科学领域常见的 Python 库,并且自带了专门用来解决软件环境依赖问题的 conda 包管理系统。主要是提供了包管理与环境管理的功能,可以很方便地解决多版本python并存、…

java学习报告

Java学习报告 目录 第一章 初识java与面向对象程序设计 1 第二章 java编程基础 3 第三章 面向对象程序设计(基础) 13 第四章 面向对象程序设计(进阶) 15 第五章 异常 17 第六章 java常用类 1720 初识java与面向对象程序设计Java概述计算机编程语言发展史“计算机之父”冯诺…

PyTorch Geometric框架下图神经网络的可解释性机制:原理、实现与评估

在机器学习领域存在一个普遍的认知误区,即可解释性与准确性存在对立关系。这种观点认为可解释模型在复杂度上存在固有限制,因此无法达到最优性能水平,神经网络之所以能够在各个领域占据主导地位,正是因为其超越了人类可理解的范畴。 其实这种观点存在根本性的谬误。研究表明…

25. K 个一组翻转链表(难)

目录题目法一、模拟--迭代法二、递归 题目给你链表的头节点 head ,每 k 个节点一组进行翻转,请你返回修改后的链表。 k 是一个正整数,它的值小于或等于链表的长度。如果节点总数不是 k 的整数倍,那么请将最后剩余的节点保持原有顺序。 你不能只是单纯的改变节点内部的值,而…

OpenWrt 系统UCI详解(Lua、C语言调用uci接口实例)

1 UCI简介 “uci"是"Unified Configuration Interface”(统一配置界面)的缩写,用于OpenWrt整个系统的配置集中化。 很多后台服务有自己的配置文件,并且配置文件格式都不相同,OpenWrt系统中需要开启各种服务,为了解决配置不兼容的问题,统一采用uci格式的配置文件。…