java - 如何将其转换为流表达式? (使用原子引用)

标签 java collections java-8 java-stream

我需要修改下面的代码:

protected void checkNoDuplicateLabels( List<CompileResult> compileResult ) {
    Set<Label> infos = new HashSet<>();
    for ( AbstractTypeInfo info : infoRepo.getList() ) {
        if ( info instanceof Label ) {
            Label label = (Label) info;
            if ( infos.contains( label ) ) {
                compileResult.add( new CompileResult( Severity.FATAL, MessageFormat.format( "Duplicate label found! \n Type: '{0}' \n Language: '{1}'", label.getType(), label.getLanguage() ) ) );
            }
            infos.add( label );
        }
    }
}

进入流。我知道将 Sets 与流一起使用的一种方法是实现 AtomicReferences,这会将方法的第一行替换为:

AtomicReference<Set<Label>> infos = new AtomicReference<>( new HashSet<Label>() );

我怎样才能实现循环现在使用流执行的相同功能?

最佳答案

你可以在没有AtomicReference的情况下做到这一点:

BinaryOperator<Label> logDuplicate = (label1, label2) -> {
    // Log label2 as duplicate
    compileResult.add(new CompileResult(Severity.FATAL, MessageFormat.format("Duplicate label found! \n Type: '{0}' \n Language: '{1}'", label2.getType(), label2.getLanguage())));
    return label1;
};

Set<Label> infos = infoRepo.getList()
                           .stream()
                           .filter(Label.class::isInstance)
                           .map(Label.class::cast)
                           .collect(toMap(identity(), identity(), logDuplicate, HashMap::new))
                           .keySet();

更新:

import static java.util.stream.Collectors.toMap;
import static java.util.function.Function.identity;

关于java - 如何将其转换为流表达式? (使用原子引用),我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/54534901/

相关文章:

java - 放冒号(:) in xml attribute

java - 为什么 Jacoco 可能会显示 0 的代码覆盖率?

java - 使用 Java 蓝图服务定义

collections - Kotlin:在 API 中公开不可变列表

java - 从 Set Java 8 中删除一个元素

java - 是否可以模拟私有(private)方法的结果并同时获得声纳或 jacoco 的覆盖?

java - 使用 ArrayListValuedHashMap 用于 MultiValuedMap 的 apache commons 的正确导入是什么

java - 获取 List 中对象的属性列表

java - 使用多个比较器多次对字符串列表进行排序

java - 删除的实体在相关实体的列表中,但我无法通过存储库找到它