场景:
在我的应用程序中(它使用丰富的领域模型,逻辑在模型中,而不是在服务中)我有用户。我用服务创建新用户
User newUser = userService.createNewUser("Hans Dampf");
或者从数据库中获取
User oldUser = userDao.findByName("Hans Dampf");
因为在对我的应用程序的每次调用中我都可以直接访问用户对象,所以我想将用户对象用作我的域模型的入口点。
每个用户可以有不同类型的画廊,保存在另一个表中。
class User {
@OneToMany(fetch = FetchType.LAZY)
@JoinColumn(name = "userId")
private Set<Gallery> automatic = new HashSet<Gallery>();
}
我想要一种启用特定图库的简单方法。所以我的 API 看起来像:
User user = ... // creating or retriving user
user.enableMainGallery();
在此方法中,需要创建一个新的画廊对象并将其添加到画廊列表中。但是如何创建这个新实例呢?使用工厂?这需要将工厂注入(inject)域对象(可能有问题)。
public void enableAutomaticGallery() {
automatic.add(automaticFactory.createAutomaticGallery(this));
}
或者我的接口(interface)定义有缺陷?我是否应该以其他方式定义它,这样我就不必注入(inject)工厂?怎么办?
最佳答案
正如您所说,域对象不应依赖于应用程序级对象,例如工厂或 Daos。
域通常是:
- 足够复杂满足功能需求,无需添加其他问题(例如持久性、验证、GUI 等...)
- 中心并随处使用(因此它的复杂性会损害您在许多编码 Activity 中的工作效率)
- 可重用在相关应用程序和所有层中,甚至可以序列化并发送到客户端或 WebService 上的不同 JVM(除非它依赖于应用程序级对象)
所以您的enableAutomaticGallery
方法应该在服务对象上。
它可以具有相同的代码,但将依赖于应用程序。
关于java - 在域模型对象中使用工厂?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/2102245/