我们有意在序列化为 JSON 的“bean”,然后返回到我们的(基于 vue.js 的)UI 层。到目前为止,我的 bean 看起来像这样:
public class ExampleBean {
private final int id;
private final String name;
public ExampleBean(int id, String name) {
this.id = id; ...
}
// getter for all fields
}
它们由一些映射器实例化:
public ExampleBean map(SomeInternalThing foo) {
int id = getIdFromFoo(foo);
String name = doSomethingElse(foo.itsBar());
return new ExampleBean(id, name);
}
然后我进行一些单元测试(针对映射器):
@Test
public void testGetId() {
... do some mocking setup so that the mapper can do its job
assertThat(mapperUnderTest.map(someFoo).getId(), is(5));
}
这种方法的主要优点是 bean 对象是不可变的(编译器会在我忘记初始化字段时告诉我)。
但是:该 bean 的字段数不断增加。 SomeInternalThing
上下文可能有 30 到 50 个“属性”,bean 中所需的字段数……现在从 3 到 5 再到 8。
真正“杀死”我的是 映射 代码为每个必填字段做不同的事情。这需要我处理越来越多的“通用”模拟规范。
现在我想知道是否有更好的选择来实现这样的“纯数据对象”。
最佳答案
在创建数据对象时,我个人更喜欢 lombok ( https://projectlombok.org/ )。它摆脱了样板代码。您应该查看“@Builder”和“@Data”注释。
由于使用 lombok 始终是团队决定,您可以从自己实现构建器模式开始(对于此类数据对象)。
这使您能够单独设置每个属性,并单独测试每个属性。
那个蜜蜂说你可能不应该对每个字段都使用构造函数。 (请参阅 Lombok 的@AllArgsConstructor) 正如你在这里看到的(https://en.wikipedia.org/wiki/JavaBeans)bean 应该有一个公共(public)的默认构造函数
关于java - 如何实现 "beans"和 "bean mapping"代码?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/45433859/