在代码重构中,用多态替代条件逻辑 是一种将冗长的条件逻辑替换为面向对象多态性的技巧。这种技术的核心思想是将不同条件分支中的行为封装到各自的子类中,从而避免在代码中出现复杂的if
-else
或switch
条件判断。通过使用多态性,可以让代码更具可读性、易于扩展,并且符合"开闭原则"(Open-Closed Principle)。
一、何时使用
用多态替代条件逻辑适用于以下场景:
- 重复的条件逻辑:代码中有多个条件分支,根据特定的状态或类型执行不同的逻辑。
- 复杂的条件分支 :
if
-else
或switch
语句变得非常复杂,难以维护和理解。 - 频繁扩展的业务需求:代码逻辑可能经常需要扩展(添加新的分支),这样子类的设计会更适合长期维护。
二、代码示例
假设我们有一个订单系统,根据不同的订单类型来计算折扣。
2.1 重构前
在重构前,代码中存在一个复杂的switch
语句:
csharp
public class Order
{
public enum OrderType { Regular, Premium, VIP }
public OrderType Type { get; set; }
public decimal Amount { get; set; }
public decimal GetDiscount()
{
switch (Type)
{
case OrderType.Regular:
return Amount * 0.05m; // 5% discount
case OrderType.Premium:
return Amount * 0.10m; // 10% discount
case OrderType.VIP:
return Amount * 0.20m; // 20% discount
default:
throw new InvalidOperationException("Unknown order type");
}
}
}
这个switch
逻辑可能会随着业务需求增加而不断扩展,每次添加新类型的订单都需要修改此方法,不符合开闭原则。
2.2 重构后
可以将每种订单类型的折扣逻辑封装到各自的子类中,使用多态来替代条件判断:
csharp
public abstract class Order
{
public decimal Amount { get; set; }
public abstract decimal GetDiscount();
}
public class RegularOrder : Order
{
public override decimal GetDiscount() => Amount * 0.05m;
}
public class PremiumOrder : Order
{
public override decimal GetDiscount() => Amount * 0.10m;
}
public class VIPOrder : Order
{
public override decimal GetDiscount() => Amount * 0.20m;
}
然后,我们在创建订单时,根据订单类型选择相应的子类:
csharp
public class OrderFactory
{
public static Order CreateOrder(string type, decimal amount)
{
Order order = type switch
{
"Regular" => new RegularOrder { Amount = amount },
"Premium" => new PremiumOrder { Amount = amount },
"VIP" => new VIPOrder { Amount = amount },
_ => throw new ArgumentException("Invalid order type")
};
return order;
}
}
使用时:
csharp
Order order = OrderFactory.CreateOrder("VIP", 1000);
decimal discount = order.GetDiscount();
Console.WriteLine($"Discount: {discount}");
三、优点
- 代码简洁:消除了条件语句,使代码更加清晰。
- 易于扩展:添加新的订单类型时,只需创建一个新的子类,而不需要修改现有代码,符合开闭原则。
- 提高可维护性:每个类的职责更加明确,便于理解和维护。
四、总结
通过"用多态替代条件逻辑"这一重构手法,我们可以将条件判断的复杂逻辑转移到类的层次结构上,从而提高代码的灵活性和可维护性。这一技术尤其适合频繁扩展的业务场景,使得新增功能的引入变得简单。