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

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

一、什么时候使用

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

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

二、优化步骤

  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. 扩展性:将数据转为对象后,未来如果需要扩展更多的行为或属性(如电话号码的地区代码、格式化等),可以更方便地添加。
相关推荐
Lojarro33 分钟前
【Spring】Spring框架之-AOP
java·mysql·spring
TianyaOAO1 小时前
mysql的事务控制和数据库的备份和恢复
数据库·mysql
Ewen Seong1 小时前
mysql系列5—Innodb的缓存
数据库·mysql·缓存
W21553 小时前
Liunx下MySQL:表的约束
数据库·mysql
nbsaas-boot4 小时前
探索 JSON 数据在关系型数据库中的应用:MySQL 与 SQL Server 的对比
数据库·mysql·json
奥顺4 小时前
PHPUnit使用指南:编写高效的单元测试
大数据·mysql·开源·php
我自是年少韶华倾负6 小时前
架构师应如何考虑重构
重构
苹果醋36 小时前
SpringBoot快速入门
java·运维·spring boot·mysql·nginx
ROCKY_8176 小时前
Mysql复习(一)
数据库·mysql
Smile丶凉轩6 小时前
MySQL库的操作
数据库·mysql·oracle