フアンPollacchi:
私は以下のコードを変更する必要があります。
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 );
}
}
}
ストリームに。私はこの方法にの最初の行を置き換えることになる、ストリームに設定を使用する1つの方法は、AtomicReferencesを実装することであることを知っています:
AtomicReference<Set<Label>> infos = new AtomicReference<>( new HashSet<Label>() );
どのように私はループが流れて今やっているのと同じ機能を実現することができますか?
ETO:
あなたはそれをせずに行うことができます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;