Список в виде потока, если он есть, иначе список не обновляется? - PullRequest
0 голосов
/ 17 июня 2019

ОБНОВЛЕНИЕ: я исправил свою проблему с этим

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 не обновила коллекцию в списке?

ИлиЕсть ли подобный подход к тому, что я пытаюсь сделать?

Пример изображения

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...