LOMBOK BUILDER-忽略具有空值的对象

发布于 2025-02-06 05:54:00 字数 476 浏览 3 评论 0原文

我与Lombok @builder的第一步。

因此,我从外部服务(内部10辆汽车)接收外部行动对象。

public class CarConverter {

    private Car convertToCar(ExternalVehicles vehicles) {

        return Car.builder()
                .plateNumber(getPlateNumberFromObjectNestedInExternalVehicles("plateNumber"))
                .brand(getBrandFromObjectNestedInExternalVehicles("brand"))
                .build();
    }
}

对于一辆汽车,在Platenumber田里收到了零。 因此,我想忽略这辆车而只转换9辆。

我该怎么做?

My first steps with Lombok @Builder.

So I receive ExternalVehicles object from external service (10 cars inside).

public class CarConverter {

    private Car convertToCar(ExternalVehicles vehicles) {

        return Car.builder()
                .plateNumber(getPlateNumberFromObjectNestedInExternalVehicles("plateNumber"))
                .brand(getBrandFromObjectNestedInExternalVehicles("brand"))
                .build();
    }
}

For one car, the null is received in plateNumber field.
So I would like to ignore this car and convert only 9.

How can I do this?

如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。

扫码二维码加入Web技术交流群

发布评论

需要 登录 才能够评论, 你可以免费 注册 一个本站的账号。

评论(1

2025-02-13 05:54:00

有多件事要提及:

  1. 您可以在转换之前过滤汽车
externalCars.stream()
     .filter(car -> Objects.nonNull() && isCarValid())
     .map(CarConverter::convertToCar)
     .collect(Collectors.toSet())
  1. ,然后在转换方法中进行一些检查,然后过滤
public class CarConverter {

    private Car convertToCar(ExternalVehicles vehicles) {
        if (vehicles == null || getPlateNumberFromObjectNestedInExternalVehicles("plateNumber") == null)
            return null

        return Car.builder()
                .plateNumber(getPlateNumberFromObjectNestedInExternalVehicles("plateNumber"))
                .brand(getBrandFromObjectNestedInExternalVehicles("brand"))
                .build();
    }
}

,然后在我的经验中过滤之前

externalCars.stream()
     .map(CarConverter::convertToCar)
     .filter(car -> Objects.nonNull())
     .collect(Collectors.toSet())

,这会导致nullpoInterExceptions

仅仅 导致为了完成,也有办法使.build()方法失败,如下所示:
https://stackoverflow.com/a/a/72654258/1538176

There are multiple things to mention:

  1. you can filter the cars before the convertion
externalCars.stream()
     .filter(car -> Objects.nonNull() && isCarValid())
     .map(CarConverter::convertToCar)
     .collect(Collectors.toSet())
  1. you can do some checks within your conversion method and filter afterwards
public class CarConverter {

    private Car convertToCar(ExternalVehicles vehicles) {
        if (vehicles == null || getPlateNumberFromObjectNestedInExternalVehicles("plateNumber") == null)
            return null

        return Car.builder()
                .plateNumber(getPlateNumberFromObjectNestedInExternalVehicles("plateNumber"))
                .brand(getBrandFromObjectNestedInExternalVehicles("brand"))
                .build();
    }
}

and then filter before the collection

externalCars.stream()
     .map(CarConverter::convertToCar)
     .filter(car -> Objects.nonNull())
     .collect(Collectors.toSet())

In my experience, this leads to less NullPointerExceptions

Just for completion, there are also way,to fail the .build() method as seen here:
https://stackoverflow.com/a/72654258/1538176

~没有更多了~
我们使用 Cookies 和其他技术来定制您的体验包括您的登录状态等。通过阅读我们的 隐私政策 了解更多相关信息。 单击 接受 或继续使用网站,即表示您同意使用 Cookies 和您的相关数据。
原文