2

对于我的交易程序,我有一个商人课程。给定的商人对象可能具有也可能不具有特定的特殊品质或特殊品质束。例如,一个 Merchant 对象可能具有 Stockbroker 品质,另一个 Merchant 可能具有 Financial Services 和 Stockbroker 品质,而另一个 Merchant 可能根本没有特殊品质。

我最初的想法是创建一个 HashMap 和一个 Qualities 类,如下所示:

Map<Qualities, Boolean> merchantQualities = new HashMap<Qualities, Boolean>();

唯一的问题是,对于商人来说至少有 50 种可能的特殊品质,因此将所有品质从 Quality 类中子类化会非常令人厌烦。

有没有比 HashMap 和子类化 Qualities 类更好的方法来编码这些可选的特殊品质并在 Merchants 类中表示它们?

4

2 回答 2

10

这一切都取决于它们是什么Qualities以及它们做什么。如果列表相当稳定,enums可能是一个很好的解决方案:

enum Quality {
  MERCHANT,
  STOCKBROKER,
  ...
}

s的好处enum是它们基本上是类,因此可以实现接口并具有状态和行为。它们还带有有用的辅助类:

Set<Quality> = EnumSet.of(MERCHANT, STOCKBROKER);

然后您可以使用所有Set功能,例如contains()等。

但在不了解更多信息的情况下,我无法告诉您这是否适合您。

编辑:在许多语言中,一个共同的起点是枚举。在 C/C++/C# 中,这将类似于:

if (merchantType == STOCKBROKER) { ... }

以下是 Java 的枚举更好的地方。假设您为股票类型定义了另一个枚举:

enum StockType {
  LISTED_EQUITIES,
  MANAGED_FUNDS
}

如果您假设给定的商家类型销售一种类型的东西:

enum MerchantType {
  STOCKBROKER(StockType.LISTED_EQUITIES),
  FINANCIAL_ADVISER(StockType.MANAGED_FUNDS);

  private final StockType stockType;

  MerchantType(StockType stockType) {
    this.stockType = stockType;
  }

  public StockType getStockType() {
    return stockType;
  }
}

所以不要说:

StockType stockType;
if (merchantType == MerchantType.STOCKBROKER) {
  stockType = StockType.EQUITIES;
}
...

你说:

StockType stockType = merchantType.getStockType();

Java 枚举具有状态和行为。这是一个非常强大的概念。

但你可以做得比这更好。与其假设每个商家一个股票,不如通过行为更好地处理:

enum MerchantType {
  STOCKBROKER,
  FINANCIAL_ADVISER;

  private static final Map<MerchantType, Set<StockType>> STOCK_TYPES;

  static {
    STOCK_TYPES = new EnumSet<MerchantType, Set<StockType>>(MerchantType.class);
    STOCK_TYPES.put(STOCKBROKER, EnumSet.of(StockType.LISTED_EQUITIES));
    STOCK_TYPES.put(FINANCIAL_ADVISER,
      EnumSet.of(StockType.LISTED_EQUITIES, StockType.MANAGED_FUNDS));
  }

  public boolean canSell(StockType stockType) {
    Set<StockType> stockTypes = STOCK_TYPES.get(this);
    return stockTypes != null && stockTypes.contains(stockType);
  }
}

此时您的代码变为:

if (merchantType.canSell(StockType.LISTED_EQUITIES)) {
  ...
}

这是一个更加自然、可读和可扩展的解决方案。

于 2010-04-17T03:40:39.873 回答
0

我想你可以在这里使用装饰器模式来用各种装饰器(股票经纪人、金融服务等)来装饰你的商家。看看 h ttp://en.wikipedia.org/wiki/Decorator_pattern

于 2010-04-17T03:57:08.037 回答