当我在我的域中有实体列表的实体时,它们应该作为IList或IEnumerables公开吗?例如Order有一堆OrderLines.
IEnumerable
表示可以迭代的一系列项目(例如,使用foreach),而IList
您可以添加或删除它们.
通常,您希望能够通过向其添加或删除OrderLines来修改订单,因此您可能希望Order.Lines成为订单IList
.
话虽如此,您应该做出一些框架设计决策.例如,是否可以将OrderLine的相同实例添加到两个不同的订单中?可能不是.因此,您希望能够验证是否应将OrderLine添加到订单中,您可能确实希望将Lines属性表示为仅一个IEnumerable
,并提供可以处理的Add(OrderLine)和Remove(OrderLine)方法验证.
大部分时间我最终使用IList而不是IEnumerable,因为IEnumerable没有Count方法,你无法通过索引访问该集合(尽管如果你使用LINQ,你可以使用扩展方法解决这个问题).