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

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

一、什么时候使用

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

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

二、优化步骤

  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. 扩展性:将数据转为对象后,未来如果需要扩展更多的行为或属性(如电话号码的地区代码、格式化等),可以更方便地添加。
相关推荐
heart000_135 分钟前
MySQL事务与锁机制详解:确保数据一致性的关键【MySQL系列】
数据库·mysql
一眼青苔40 分钟前
MySQL 如何判断某个表中是否存在某个字段
数据库·mysql
智驱力人工智能2 小时前
高密爆炸警钟长鸣:AI为化工安全戴上“智能护盾”
人工智能·算法·安全·重构·边缘计算·高密爆炸·高密化工厂
天空之城夢主2 小时前
MySQL 全量、增量备份与恢复
数据库·mysql·oracle
依稀i1234 小时前
MySQL连接报SSL错误
数据库·mysql·ssl
kaede4 小时前
MySQL权限详解!
数据库·mysql
萝卜白菜。6 小时前
关于TongWeb数据源兼容mysql驱动的注意事项
java·mysql
进击的CJR6 小时前
MySQL 8.0 OCP 英文题库解析(十一)
mysql·adb·开闭原则
郝同学的测开笔记7 小时前
深入解析:如何优雅计算时间区间内的有效时长
后端·mysql·测试
平平无奇。。。9 小时前
Mysql库的操作和表的操作
linux·数据库·mysql