在我们的项目中,我们经常根据一些条件选择算法。
例如,假设我们需要打印不同产品的订单。我们需要根据产品类型、价格或任何其他产品特性选择不同的空白并检索不同的数据。通常,我们会写这样的东西。
public interface IOrderPrinter
{
bool CanPrint(Order order);
PrintResult Print(Order order);
}
class CompositeOrderPrinter : IOrderPrinter
{
private IList<IOrderPrinter> printers;
public bool CanPrint(Order order)
{
return printers.Any(p => p.CanPrint(order));
}
public PrintResult Print(Order order)
{
foreach (var printer in printers)
{
if (printer.CanPrint(order))
return printer.Print(order);
}
// throw some exception
}
public void AddPrinter(IOrderPrinter printer)
{
printers.Add(printer);
}
}
class FirstOrderPrinter : IOrderPrinter
{
public bool CanPrint(Order order)
{
return order.ProductType == ProductType.Banana && order.Price < 100;
}
public PrintResult Print(Order order)
{
if (!CanPrint)
// throw some exception
// print ...
}
}
class SecondOrderPrinter : IOrderPrinter
{
public bool CanPrint(Order order)
{
return order.ProductType == ProductType.Apple;
}
public PrintResult Print(Order order)
{
if (!CanPrint)
// throw some exception
// print ...
}
}
这个模式有什么众所周知的名字吗?是的,它看起来与复合模式非常相似,但还是有区别的。是否有任何标准设计模式可以更好(更优雅,更少代码,......)方式解决此任务?阅读有关实现类似行为的另一种方法会很有趣。