在涉足领域驱动设计时,我遇到了关于如何在我的领域模型中识别聚合根的情况。
我有以下三个类,建模一个简单的待办事项列表:
public class List {
private IList<Task> _tasks;
public List() { ... }
public string Name { get; set; } }
public IEnumerable<Task> Tasks() { ... }
public void AddTask(string descr) { ... }
public void RemoveTask(Task t) { ... }
public Task GetRandomTask() { ... }
}
public class Task {
private IList<Update> _updates;
public Task(string descr) { ... }
public string Description { get; }
public bool IsClosed { get; }
public IEnumerable<Update> Updates() { ... }
public void AddUpdate(string descr, bool close) { ... }
}
public class Update {
public Update(string descr) { ... }
public string Description { get; }
}
关于模型,我可以说明以下内容:
- 更新仅存在于任务的上下文中。
- 任务仅存在于列表的上下文中。
因此,列表似乎是唯一的聚合根。(实际上,我的数据访问层只允许加载/保存 List 对象。)但是我看不到如何将我的 Task 类中当前存在的 UI 干净地推送到 List 类。目前我的 List 类正在分发对 Task 对象的引用,允许调用者修改它们。
这是否意味着 Task 也是一个聚合根,即使它的存在依赖于包含列表?
提前致谢。