Uso de Java 8 Corriente para reemplazar a bucle y rellenar un mapa

user9569944:

En esta asignación java tenemos un bucle que lee a través de un archivo de texto que usamos en este programa, y ​​se supone que debemos sustituirlo por una corriente. He aquí parte del programa y lo que se supone para reemplazar:

    import java.io.FileNotFoundException;
    import java.util.List;
    import java.util.Map;
    import java.util.TreeMap;


    public class FrequentWords {

    public static void main(String[] args) throws FileNotFoundException {

    String filename = "SophieSallyJack.txt";
    if (args.length == 1) {
        filename = args[0];
    }
    Map<String, Integer> wordFrequency = new TreeMap<>();

    List<String> incoming = Utilities.readAFile(filename);

    // TODO replace the following loop with a single statement using streams    
    // that populates wordFrequency         
    for (String word : incoming) {
        word = word.toLowerCase();
        if (!"".equals(word.trim())) {
            Integer cnt = wordFrequency.get(word);
            if (cnt == null) {
                wordFrequency.put(word, 1);
            } else {
                int icnt = cnt + 1;
                wordFrequency.put(word, icnt);
            }
        }
    }

He intentado esto y no puedo parecer imaginar cualquier otra cosa:

incoming.stream()
        .collect(Collectors.toMap(word -> word, word -> 1, Integer::sum)).entrySet();
Shubhendu Pramanik:

Esto es lo que puede probar:

wordFrequency = incoming.stream()
               .map(String::toLowerCase).filter(word -> !word.trim().isEmpty())
               .collect(Collectors.toMap
                (word -> word, word -> 1, (a, b) -> a + b, TreeMap::new));

Se ha perdido los BinaryOperatorvalores que se fusionarán de la keyque ya existeCollectors.toMap()

Supongo que te gusta

Origin http://43.154.161.224:23101/article/api/json?id=179602&siteId=1
Recomendado
Clasificación