博客
关于我
你的代码需要重构吗?
阅读量:733 次
发布时间:2019-03-22

本文共 641 字,大约阅读时间需要 2 分钟。

当你在编写代码时,养成审视自己的习惯,将一段代码反复读上五六遍,每次都会发现新的问题。这种习惯是代码重构的基础,而重构则意味着对现有代码进行改善,以提升其质量和可维护性。在进行重构之前,你需要明确哪些代码需要改善。

编写代码时最常见的设计问题往往源于以下几个方面:

  • 代码重复:如果你发现同一段逻辑代码多次出现,很可能存在重复代码问题。
  • 代码长度过长:一个长达几百行的方法通常意味着逻辑过于复杂,需要进行分解。
  • 条件逻辑过于复杂:复杂的条件判断可能意味着设计存在问题。
  • 基本类型迷恋:过度使用primitive类型可能会导致代码难以维护。
  • 不恰当的暴露:某些私有属性或方法被错误地暴露在外可能会引发安全问题。
  • 解决方案蔓延:在系统中快速添加新功能而不进行设计优化,往往导致代码质量下降。
  • 异曲同工的类:如果发现两个类功能相似,通常可以通过继承或组合来优化。
  • 冗赘的类:一个类如果承担了过多的职责,很可能需要拆分成多个小类。
  • 类过大:一个庞大的类往往难以维护和扩展,应考虑将其拆分。
  • 过度的分支语句:复杂的switch语句可能导致代码难以维护,应优化为多态或继承结构。
  • 组合爆炸:如果每个方法都有独特的查询逻辑,随着查询类型增加,代码会变得难以管理。
  • 怪异解决方案:在同一系统中使用不同的解决方案来处理相同问题,往往会导致代码混乱。
  • Fowler和Beck提出的这些代码坏味可以帮助开发者识别需要改进的代码区域。通过定期审查代码,并针对性地进行重构,你可以显著提升代码的质量和可维护性。

    转载地址:http://zakwk.baihongyu.com/

    你可能感兴趣的文章
    nginx配置全解
    查看>>
    Nginx配置参数中文说明
    查看>>
    nginx配置域名和ip同时访问、开放多端口
    查看>>
    Nginx配置好ssl,但$_SERVER[‘HTTPS‘]取不到值
    查看>>
    Nginx配置如何一键生成
    查看>>
    Nginx配置实例-负载均衡实例:平均访问多台服务器
    查看>>
    Nginx配置文件nginx.conf中文详解(总结)
    查看>>
    Nginx配置负载均衡到后台网关集群
    查看>>
    ngrok | 内网穿透,支持 HTTPS、国内访问、静态域名
    查看>>
    NHibernate学习[1]
    查看>>
    NHibernate异常:No persister for的解决办法
    查看>>
    NIFI1.21.0_Mysql到Mysql增量CDC同步中_日期类型_以及null数据同步处理补充---大数据之Nifi工作笔记0057
    查看>>
    NIFI1.21.0_NIFI和hadoop蹦了_200G集群磁盘又满了_Jps看不到进程了_Unable to write in /tmp. Aborting----大数据之Nifi工作笔记0052
    查看>>
    NIFI1.21.0通过Postgresql11的CDC逻辑复制槽实现_指定表多表增量同步_增删改数据分发及删除数据实时同步_通过分页解决变更记录过大问题_02----大数据之Nifi工作笔记0054
    查看>>
    NIFI从MySql中增量同步数据_通过Mysql的binlog功能_实时同步mysql数据_根据binlog实现数据实时delete同步_实际操作04---大数据之Nifi工作笔记0043
    查看>>
    NIFI从MySql中增量同步数据_通过Mysql的binlog功能_实时同步mysql数据_配置binlog_使用处理器抓取binlog数据_实际操作01---大数据之Nifi工作笔记0040
    查看>>
    NIFI从MySql中增量同步数据_通过Mysql的binlog功能_实时同步mysql数据_配置数据路由_实现数据插入数据到目标数据库_实际操作03---大数据之Nifi工作笔记0042
    查看>>
    NIFI从MySql中离线读取数据再导入到MySql中_03_来吧用NIFI实现_数据分页获取功能---大数据之Nifi工作笔记0038
    查看>>
    NIFI从PostGresql中离线读取数据再导入到MySql中_带有数据分页获取功能_不带分页不能用_NIFI资料太少了---大数据之Nifi工作笔记0039
    查看>>
    NIFI同步MySql数据_到SqlServer_错误_驱动程序无法通过使用安全套接字层(SSL)加密与SQL Server_Navicat连接SqlServer---大数据之Nifi工作笔记0047
    查看>>