下面是我的代码:
void deleteTranslationIfUpdated(Stream<MediaTranslation> from, Stream<MediaTranslationDTO> data) {
Stream<MediaTranslation> newLogos = data
.map(mediaTranslationMapper::mapToEntity)
.collect(Collectors.toList())
.stream();
from.filter(e ->
newLogos.noneMatch(it ->
Objects.equals(e.getLang(), it.getLang()) && Objects.equals(e.getValue().getLink(), it.getValue().getLink())))
.map(MediaTranslation::getValue)
.map(Media::getLink)
.filter(this::isNotHttpLink)
.forEach(storageService::delete);
}
从下面的函数调用上面的函数:
@Secured({AuthoritiesConstants.USER})
public BrandDTO update(String id, BrandDTO data) throws EntityNotFound {
log.debug("Request to update Brand : {} with {}", id, data);
return Optional.ofNullable(brandRepository.findOne(id))
.map(from -> {
mediaService.deleteTranslationIfUpdated(from.getLogo().stream(), data.getLogo().stream());
return from;
})
.map(target -> brandMapper.updateFromDto(data, target))
.map(brandRepository::save)
.map(brandMapper::mapToDto)
.map(this::copyCategoriesInZone)
.orElseThrow(EntityNotFound::new);
}
我不知道为什么。
第二个流管道尝试多次处理newlogos
流。这是不可能的。一个流只能处理一次。
您必须为每次执行from.filter()
重新创建该流,或者找到一种不同的方法来实现您要做的事情。
你可以做的一件事是:
List<MediaTranslation> newLogos = data
.map(mediaTranslationMapper::mapToEntity)
.collect(Collectors.toList());
将第二个流管道中的newlogos
替换为newlogos.stream()
。
方法是 现在我试着像这样改成stream,但我不知道这种改是否正确: 如何避免出现例外,解决问题? 我应该以某种方式重构代码吗?
我想复制一个Java8流,这样我可以处理它两次。我可以
我想复制一个Java 8流,这样我可以处理它两次。我可以作为列表并从中获取新流; 但我觉得应该有一个更高效/更优雅的方法。 有没有一种方法可以复制流而不将其变成集合? 我实际上正在处理一个流,所以在移动到右侧投影并以另一种方式处理之前,希望先以一种方式处理左侧投影。类似于这样(到目前为止,我不得不使用技巧)。
问题内容: 我正在尝试使用Stream API生成Order实例。我有一个创建订单的工厂函数,并且使用DoubleStream初始化订单金额。 如果我使用文字(1.0)初始化Order实例,则可以正常工作。当我使用doubleStream创建随机数量时,将引发异常。 问题答案: 答案在(重点是我的)的javadoc中: 流仅应操作一次(调用中间流或终端流操作) 。例如,这排除了“分叉”流,其中相同
问题内容: 我想复制一个Java 8流,以便可以处理两次。我可以collect列出并从中获得新的信息流; 但我认为应该有一种更有效/更优雅的方法。 有没有一种方法可以复制流而不将其转换为集合? 我实际上正在使用 流,因此想先处理左侧投影,然后再移至右侧投影并以另一种方式处理。有点像这样(到目前为止,我被迫使用这种技巧)。 问题答案: 你可以将局部变量与一起使用,以设置流管道的公共部分。 从http