系统重构时优化关于枚举和字符串

本贴最后更新于 3325 天前,其中的信息可能已经天翻地覆

最近在重构同事写的代码,代码设计的非常好,由于涉及到的类比较多,我这里就以一个枚举类来记录关于枚举和字符串的优化(不涉及到业务部分)

代码如下:

package com.vcg.community.data.constant;
public enum InvokerTypeEnum {
    //读操作
    ReadEntityById {
        public String cmdClassName() {return "com.vcg.community.data.command.read.EntityByIdCmd";}
    },
    ReadEntityByIndex {
        public String cmdClassName() {return "com.vcg.community.data.command.read.EntityByIndexCmd";}
    },
    ReadEntityByLink{
        public String cmdClassName() {return "com.vcg.community.data.command.read.EntityByLinkCmd";}
    },
    ReadEntityByColumn{
        public String cmdClassName() {return "com.vcg.community.data.command.read.EntityByColumnCmd";}
    },
    ReadCount {
        public String cmdClassName() {return "com.vcg.community.data.command.read.CountCmd";}
    },
    ReadCountByLink {
        public String cmdClassName() {return "com.vcg.community.data.command.read.CntByLinkCmd";}
    },
    ReadStateByLink {
        public String cmdClassName() {return "com.vcg.community.data.command.read.StateByLinkCmd";}
    },
    Search {
        public String cmdClassName() {return "com.vcg.community.data.command.read.SearchCmd";}
    },
Msg { public String cmdClassName() {return "com.vcg.community.data.command.read.MsgCmd";} }, ReadEntityBySql { public String cmdClassName() {return "com.vcg.community.data.command.read.EntityBySqlCmd";} }, SearchBySql { public String cmdClassName() {return "com.vcg.community.data.command.read.SearchBySqlCmd";} }, QueryCountBySql { public String cmdClassName() {return "com.vcg.community.data.command.read.QueryCountBySqlCmd";} }, QueryIdsBySql { public String cmdClassName() {return "com.vcg.community.data.command.read.QueryIdsBySqlCmd";} }, //写操作 InsertEntitys{ public String cmdClassName() {return "com.vcg.community.data.command.write.InsertEntitysCmd";} }, DeleteEntitys{ public String cmdClassName() {return "com.vcg.community.data.command.write.DeleteEntitysCmd";} }, DoLinks{ public String cmdClassName() {return "com.vcg.community.data.command.write.DoLinksCmd";} }, UndoLinks{ public String cmdClassName() {return "com.vcg.community.data.command.write.UndoLinksCmd";} }, WriteOther{ public String cmdClassName() {return "com.vcg.community.data.command.write.WriteOtherCmd";} }, ChangeCount{ public String cmdClassName() {return "com.vcg.community.data.command.write.ChangeCountCmd";} }; public abstract String cmdClassName() ;

}

上下文代码

InvokerTypeEnum invokeType = inputObject.getInvokeType();
        if (invokeType == null) {
            return new OutputObject(OutputObject.CODE_ERROR, "the attr invoke_type can not be null");
        }
        String className = invokeType.cmdClassName();
        AbstractCommand dp = (AbstractCommand) SpringUtils.getBeanByClassName(className);
        outputObject = dp.checkInputAttr(inputObject);
        if (outputObject.getCode() == OutputObject.CODE_ERROR) {
            return outputObject;
        }
        outputObject = dp.execute(inputObject);
        return outputObject;
    }
public abstract class AbstractCommand {
    @Autowired
    protected RedisStrategy redisStrategy;
    @Autowired
    protected MysqlStrategy mysqlStrategy;
    @Autowired
    protected SearchStrategy searchStrategy;
    public abstract OutputObject execute(InputObject inputObject);
    public abstract OutputObject checkInputAttr(InputObject inputObject);
}

优化后的代码:

public enum InvokerType {
    //读操作
    ReadEntityById,
    ReadEntityByIndex,
    ReadEntityByLink,
    ReadEntityByColumn,
    ReadCount,
    ReadCountByLink,
    ReadStateByLink,
    Search,
    Msg,
    ReadEntityBySql,
    SearchBySql,
    QueryCountBySql,
    QueryIdsBySql,
    //写操作
    InsertEntitys,
    DeleteEntity,
    DoLinks,
    UndoLinks,
    WriteOther,
    ChangeCount;
    String cmdClassName(){return this.getClass().getPackage().getName()+".command."+this.name()+"Cmd";}
}

这样一来,是不是更合理了呢?我们来分析一下

1.首先从代码的数量来说,是不是更精简了一些。
2.形式来说,避开了抽象枚举,是不是更接近普通的枚举设计。
3.性能来说,同事的方式会让JVM产生更多的类似“com.vcg.community.data.command.read/write.xxxxx”的字符串常量(不是new出来的字符串都会在编译期间存入常量池中)
4.系统扩展性,当系统可能会新增该枚举类型时,优化后的方式更利于系统扩展,仅需新增一个枚举值即可。
5.系统稳定性,减少可能由于字符输入(大小写,非复制手敲等原因)错误而造成spring无法加载模板实例的可能性


最终,同事在我的说服下同意了我的修改。

  • 系统重构经历
    1 引用 • 3 回帖
  • 设计模式

    设计模式(Design pattern)代表了最佳的实践,通常被有经验的面向对象的软件开发人员所采用。设计模式是软件开发人员在软件开发过程中面临的一般问题的解决方案。这些解决方案是众多软件开发人员经过相当长的一段时间的试验和错误总结出来的。

    200 引用 • 120 回帖
  • 架构师
    7 引用 • 23 回帖 • 1 关注

相关帖子

欢迎来到这里!

我们正在构建一个小众社区,大家在这里相互信任,以平等 • 自由 • 奔放的价值观进行分享交流。最终,希望大家能够找到与自己志同道合的伙伴,共同成长。

注册 关于
请输入回帖内容 ...
  • qutopia

    如果数据库的类型性如用户类型的字段想用枚举字段存储,数据库的字段设计用什么类型? 又或者设计枚举做怎样的折中呢

  • felayman
    作者

    @qutopia 我们一般是用整型来表示用户类型,一般的理念,就 mysql 而言,在做表结构和 java 的 model 映射的时候,建议都使用基本数据类型,无法使用基本数据类型,建议使用父子表设计

  • qutopia

    @felayman 在代码中,这个类型变量 你们是比较倾向于静态变量还是用枚举表示

felayman
专注于系统架构以及搜索服务 北京

推荐标签 标签

  • Python

    Python 是一种面向对象、直译式电脑编程语言,具有近二十年的发展历史,成熟且稳定。它包含了一组完善而且容易理解的标准库,能够轻松完成很多常见的任务。它的语法简捷和清晰,尽量使用无异义的英语单词,与其它大多数程序设计语言使用大括号不一样,它使用缩进来定义语句块。

    556 引用 • 675 回帖
  • 支付宝

    支付宝是全球领先的独立第三方支付平台,致力于为广大用户提供安全快速的电子支付/网上支付/安全支付/手机支付体验,及转账收款/水电煤缴费/信用卡还款/AA 收款等生活服务应用。

    29 引用 • 347 回帖 • 1 关注
  • 链滴

    链滴是一个记录生活的地方。

    记录生活,连接点滴

    171 引用 • 3847 回帖
  • GitLab

    GitLab 是利用 Ruby 一个开源的版本管理系统,实现一个自托管的 Git 项目仓库,可通过 Web 界面操作公开或私有项目。

    46 引用 • 72 回帖
  • SMTP

    SMTP(Simple Mail Transfer Protocol)即简单邮件传输协议,它是一组用于由源地址到目的地址传送邮件的规则,由它来控制信件的中转方式。SMTP 协议属于 TCP/IP 协议簇,它帮助每台计算机在发送或中转信件时找到下一个目的地。

    4 引用 • 18 回帖 • 637 关注
  • Kubernetes

    Kubernetes 是 Google 开源的一个容器编排引擎,它支持自动化部署、大规模可伸缩、应用容器化管理。

    116 引用 • 54 回帖 • 1 关注
  • Kotlin

    Kotlin 是一种在 Java 虚拟机上运行的静态类型编程语言,由 JetBrains 设计开发并开源。Kotlin 可以编译成 Java 字节码,也可以编译成 JavaScript,方便在没有 JVM 的设备上运行。在 Google I/O 2017 中,Google 宣布 Kotlin 成为 Android 官方开发语言。

    19 引用 • 33 回帖 • 78 关注
  • 链书

    链书(Chainbook)是 B3log 开源社区提供的区块链纸质书交易平台,通过 B3T 实现共享激励与价值链。可将你的闲置书籍上架到链书,我们共同构建这个全新的交易平台,让闲置书籍继续发挥它的价值。

    链书社

    链书目前已经下线,也许以后还有计划重制上线。

    14 引用 • 257 回帖
  • Ant-Design

    Ant Design 是服务于企业级产品的设计体系,基于确定和自然的设计价值观上的模块化解决方案,让设计者和开发者专注于更好的用户体验。

    17 引用 • 23 回帖
  • Android

    Android 是一种以 Linux 为基础的开放源码操作系统,主要使用于便携设备。2005 年由 Google 收购注资,并拉拢多家制造商组成开放手机联盟开发改良,逐渐扩展到到平板电脑及其他领域上。

    335 引用 • 324 回帖
  • IBM

    IBM(国际商业机器公司)或万国商业机器公司,简称 IBM(International Business Machines Corporation),总公司在纽约州阿蒙克市。1911 年托马斯·沃森创立于美国,是全球最大的信息技术和业务解决方案公司,拥有全球雇员 30 多万人,业务遍及 160 多个国家和地区。

    17 引用 • 53 回帖 • 146 关注
  • Spark

    Spark 是 UC Berkeley AMP lab 所开源的类 Hadoop MapReduce 的通用并行框架。Spark 拥有 Hadoop MapReduce 所具有的优点;但不同于 MapReduce 的是 Job 中间输出结果可以保存在内存中,从而不再需要读写 HDFS,因此 Spark 能更好地适用于数据挖掘与机器学习等需要迭代的 MapReduce 的算法。

    74 引用 • 46 回帖 • 569 关注
  • 区块链

    区块链是分布式数据存储、点对点传输、共识机制、加密算法等计算机技术的新型应用模式。所谓共识机制是区块链系统中实现不同节点之间建立信任、获取权益的数学算法 。

    92 引用 • 752 回帖
  • 笔记

    好记性不如烂笔头。

    310 引用 • 794 回帖
  • CentOS

    CentOS(Community Enterprise Operating System)是 Linux 发行版之一,它是来自于 Red Hat Enterprise Linux 依照开放源代码规定释出的源代码所编译而成。由于出自同样的源代码,因此有些要求高度稳定的服务器以 CentOS 替代商业版的 Red Hat Enterprise Linux 使用。两者的不同在于 CentOS 并不包含封闭源代码软件。

    239 引用 • 224 回帖
  • 房星科技

    房星网,我们不和没有钱的程序员谈理想,我们要让程序员又有理想又有钱。我们有雄厚的房地产行业线下资源,遍布昆明全城的 100 家门店、四千地产经纪人是我们坚实的后盾。

    6 引用 • 141 回帖 • 590 关注
  • GitHub

    GitHub 于 2008 年上线,目前,除了 Git 代码仓库托管及基本的 Web 管理界面以外,还提供了订阅、讨论组、文本渲染、在线文件编辑器、协作图谱(报表)、代码片段分享(Gist)等功能。正因为这些功能所提供的便利,又经过长期的积累,GitHub 的用户活跃度很高,在开源世界里享有深远的声望,并形成了社交化编程文化(Social Coding)。

    210 引用 • 2040 回帖
  • 快应用

    快应用 是基于手机硬件平台的新型应用形态;标准是由主流手机厂商组成的快应用联盟联合制定;快应用标准的诞生将在研发接口、能力接入、开发者服务等层面建设标准平台;以平台化的生态模式对个人开发者和企业开发者全品类开放。

    15 引用 • 127 回帖 • 1 关注
  • 又拍云

    又拍云是国内领先的 CDN 服务提供商,国家工信部认证通过的“可信云”,乌云众测平台认证的“安全云”,为移动时代的创业者提供新一代的 CDN 加速服务。

    20 引用 • 37 回帖 • 573 关注
  • PHP

    PHP(Hypertext Preprocessor)是一种开源脚本语言。语法吸收了 C 语言、 Java 和 Perl 的特点,主要适用于 Web 开发领域,据说是世界上最好的编程语言。

    179 引用 • 408 回帖 • 488 关注
  • 酷鸟浏览器

    安全 · 稳定 · 快速
    为跨境从业人员提供专业的跨境浏览器

    3 引用 • 59 回帖 • 47 关注
  • Rust

    Rust 是一门赋予每个人构建可靠且高效软件能力的语言。Rust 由 Mozilla 开发,最早发布于 2014 年 9 月。

    58 引用 • 22 回帖 • 9 关注
  • Follow
    4 引用 • 12 回帖 • 9 关注
  • Mobi.css

    Mobi.css is a lightweight, flexible CSS framework that focus on mobile.

    1 引用 • 6 回帖 • 756 关注
  • Solo

    Solo 是一款小而美的开源博客系统,专为程序员设计。Solo 有着非常活跃的社区,可将文章作为帖子推送到社区,来自社区的回帖将作为博客评论进行联动(具体细节请浏览 B3log 构思 - 分布式社区网络)。

    这是一种全新的网络社区体验,让热爱记录和分享的你不再感到孤单!

    1441 引用 • 10068 回帖 • 494 关注
  • 七牛云

    七牛云是国内领先的企业级公有云服务商,致力于打造以数据为核心的场景化 PaaS 服务。围绕富媒体场景,七牛先后推出了对象存储,融合 CDN 加速,数据通用处理,内容反垃圾服务,以及直播云服务等。

    28 引用 • 226 回帖 • 134 关注
  • Electron

    Electron 基于 Chromium 和 Node.js,让你可以使用 HTML、CSS 和 JavaScript 构建应用。它是一个由 GitHub 及众多贡献者组成的活跃社区共同维护的开源项目,兼容 Mac、Windows 和 Linux,它构建的应用可在这三个操作系统上面运行。

    15 引用 • 136 回帖 • 3 关注