ОБНОВЛЕНИЕ: я исправил свою проблему с этим
Optional<Collection<Pair<String, Integer>>> collResult = shufflingResult.stream().filter(c -> c.contains(uniquePair)).findAny();
if(collResult.isPresent()) {
collResult.ifPresent(c -> {
for(int i = 0; i < pFrequencyCount; i++)
c.add(uniquePair);
});
}
else {
Collection<Pair<String, Integer>> newColl = new ArrayList<>();
for(int i = 0; i < pFrequencyCount; i++)
newColl.add(uniquePair);
shufflingResult.add(newColl);
}
Но мне все еще интересно, почему ifPresentOrElse не обновляет список, в то время как просто ifPresent делает.
IПытаюсь реализовать аналогичный freamwork MapReduce, в фазе тасования я делаю что-то вроде того, что показано ниже, но когда я передаю получателя коллекции методу ifPresentOrElse, значение этой коллекции не обновляется в списке
public class ExecutingController implements Initializable {
@FXML
Button startBtn;
private List<String> fileLines;
ExecutorService executor;
List<Collection<Pair<String, Integer>>> shufflingResult;
public ExecutingController() {
fileLines = new ArrayList<>();
shufflingResult = new ArrayList<>();
executor = Executors.newCachedThreadPool();
}
private void init() {
startBtn.setOnAction(e -> {
fileLines = getInputFileLines();
try {
startMappingPhase();
} catch (Exception ex) {
ex.printStackTrace();
Utils.showFatalError(ex.toString());
}
});
}
@Override
public void initialize(URL url, ResourceBundle resourceBundle) {
init();
}
private void startMappingPhase() throws Exception {
for (String line : fileLines) {
Future future = new ExecutingController().mapping(line);
while (!future.isDone()) {
//
}
shuffle((Collection<Pair<String, Integer>>) future.get());
}
}
private void shuffle(Collection<Pair<String, Integer>> pairs) {
// Get a unique set of pairs
Set<Pair<String, Integer>> uniquePairs = new LinkedHashSet<>(pairs);
// Loop through set
for (Pair<String, Integer> uniquePair : uniquePairs) {
// Get a unique pair frequency count
int pFrequencyCount = Collections.frequency(pairs, uniquePair);
// Get a stream of result list and check if it's collections has that unique pair if so append it
// else make a new collection then append it
shufflingResult.stream().filter(c -> c.contains(uniquePair)).findAny().ifPresentOrElse(new Consumer<Collection<Pair<String, Integer>>>() {
@Override
public void accept(Collection<Pair<String, Integer>> ps) {
for (int i = 0; i < pFrequencyCount; i++)
ps.add(uniquePair); /* My problem here, I don't get the collection(ps) updated in the list(shufflingResult). */
}
}, new Runnable() {
@Override
public void run() {
Collection<Pair<String, Integer>> newColl = new ArrayList<>();
for (int i = 0; i < pFrequencyCount; i++)
newColl.add(uniquePair);
shufflingResult.add(newColl);
}
});
}
}
private Future<Collection<Pair<String, Integer>>> mapping(String segment) throws Exception {
Path clsPath = Paths.get(Utils.getAppTempFolder(), "Mapping.class");
Invoker invoker = new Invoker(clsPath, "Mapping", "mapper");
return executor.submit(() -> {
return (Collection<Pair<String, Integer>>) invoker.invoke(segment);
});
}
private List<String> getInputFileLines() {
return Utils.getFileLines(Paths.get(Utils.getAppTempFolder(), "input.txt").toFile());
}
}
Но если я просто вызову ifPresent с лямбда-коллекцией, обновится в списке.
shufflingResult.stream().filter(c -> c.contains(uniquePair)).findAny().ifPresent(c -> {
for(int i = 0; i < pFrequencyCount; i++)
c.add(uniquePair);
});
У меня вопрос, почему коллекция ifPresentOrElse не обновила коллекцию в списке?
ИлиЕсть ли подобный подход к тому, что я пытаюсь сделать?
Пример изображения