重构复杂简单变量之用对象替换数据值

对象替换数据值用于将简单的数据值替换为具有行为和逻辑的对象。这种优化的目的在于提高代码的可读性、灵活性和可维护性,尤其是在数据开始承载更多含义或行为的时候。

一、什么时候使用

当我们在代码中使用简单的数据值(如字符串、整数)表示一个有更复杂含义的概念时,使用对象来封装数据会更加合适。例如:

  • 某个值可能需要附加逻辑进行验证或格式化。
  • 相同的值在多个地方使用,但行为不一致,容易产生错误。
  • 简单数据值开始变得复杂,包含额外的计算、转换或状态。

二、优化步骤

  1. 识别简单的数据值 :首先找到那些不再单纯作为数据存在的值。比如我们有个表示货币金额的 decimaldouble 类型,但它其实包含了货币的业务逻辑(比如货币类型、汇率等)。
  2. 创建类封装数据 :将该数据值封装成一个类,属性用于保存原始值,并在这个类中添加需要的行为。例如我们可以创建一个 Money 类来代替简单的金额值。
  3. 移植相关行为:如果该数据值的使用中已经有了一些行为逻辑,比如验证、格式化等,将这些行为方法移植到新类中。
  4. 替换数据值:在需要使用这个值的地方,将其替换为新创建的对象。

三、示例

假设我们有以下代码,直接使用字符串来表示客户的电话号码:

csharp 复制代码
public class Customer
{
    public string PhoneNumber { get; set; }
}

优化后的代码,可以创建一个 PhoneNumber 类,封装电话号码的相关行为:

csharp 复制代码
public class PhoneNumber
{
    public string Number { get; private set; }

    public PhoneNumber(string number)
    {
        if (!IsValidPhoneNumber(number))
        {
            throw new ArgumentException("Invalid phone number format.");
        }
        Number = number;
    }

    private bool IsValidPhoneNumber(string number)
    {
        // 这里添加电话号码验证逻辑
        return Regex.IsMatch(number, @"^\d{10}$");
    }

    public override string ToString()
    {
        return Number;
    }
}

然后在 Customer 类中使用新的 PhoneNumber 对象:

csharp 复制代码
public class Customer
{
    public PhoneNumber PhoneNumber { get; set; }

    public Customer(PhoneNumber phoneNumber)
    {
        PhoneNumber = phoneNumber;
    }
}

四、优化的好处

  1. 清晰性和可读性:用对象表示的数据更加清晰,能表达其实际含义,也避免了使用不合适的值。
  2. 行为封装:将与数据相关的行为封装在对象中,避免重复代码和错误。
  3. 更易维护:当需要修改数据的表现形式或处理方式时,只需修改对象类中的方法,而不需要改动多处业务逻辑。
  4. 扩展性:将数据转为对象后,未来如果需要扩展更多的行为或属性(如电话号码的地区代码、格式化等),可以更方便地添加。
相关推荐
我星期八休息3 小时前
Linux系统编程—mmap文件映射
java·linux·运维·服务器·数据库·mysql·spring
网管NO.13 小时前
MySQL 8.0 JSON 操作 | 新增 / 查询 / 修改,适配新兴业务
数据库·mysql·json
IT策士4 小时前
MySQL 系列:第1篇 数据库时代与MySQL
数据库·mysql
我爱学习好爱好爱5 小时前
Docker Compose部署SpringBoot2+Vue3+redis项目(Rockylinux9.6):MySQL 主从复制实战
redis·mysql·docker
不吃土豆的马铃薯5 小时前
高并发服务器数据库连接池设计详解
服务器·网络·数据库·c++·mysql
Nontee5 小时前
新手数据库进阶:大白话图解MySQL的“官方档案”——Binlog
数据库·mysql
基德爆肝c语言6 小时前
MySQL:数据库基础
数据库·mysql
左直拳1 天前
mysql分区表自动归档
mysql·分区表·分区表归档
haven-8521 天前
MySQL事务ACID、隔离级别、MVCC、幻读解决
数据库·mysql
一线灵1 天前
Axmol 3.x 输入系统重构:从 Touch/Mouse 到统一 Pointer,再到现代 InputField
重构·游戏引擎