gpt4 book ai didi

java - 如何实现 "beans"和 "bean mapping"代码?

转载 作者:塔克拉玛干 更新时间:2023-11-02 19:49:53 25 4
gpt4 key购买 nike

我们有意在序列化为 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/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com