Refactor a method to using stream APIIs there a concise way to iterate over a stream with indices in Java 8?Why does Stream<T> not implement Iterable<T>?Should I always use a parallel stream when possible?Custom thread pool in Java 8 parallel streamHow to Convert a Java 8 Stream to an Array?Convert Iterable to Stream using Java 8 JDKWhat's the difference between map and flatMap methods in Java 8?Why are Java Streams once-off?How to sum a list of integers with java streams?Populate a map conditionally using streams - Java 8

Go Pregnant or Go Home

How to safely derail a train during transit?

What is paid subscription needed for in Mortal Kombat 11?

Is this apparent Class Action settlement a spam message?

Is a stroke of luck acceptable after a series of unfavorable events?

You cannot touch me, but I can touch you, who am I?

Is exact Kanji stroke length important?

What is the opposite of 'gravitas'?

Do the temporary hit points from the Battlerager barbarian's Reckless Abandon stack if I make multiple attacks on my turn?

How can I get through very long and very dry, but also very useful technical documents when learning a new tool?

Hostile work environment after whistle-blowing on coworker and our boss. What do I do?

How does buying out courses with grant money work?

Inappropriate reference requests from Journal reviewers

Avoiding estate tax by giving multiple gifts

Is there a problem with hiding "forgot password" until it's needed?

Proof of work - lottery approach

What is the difference between "behavior" and "behaviour"?

Large drywall patch supports

Escape a backup date in a file name

Customer Requests (Sometimes) Drive Me Bonkers!

Why not increase contact surface when reentering the atmosphere?

Increase performance creating Mandelbrot set in python

Implement the Thanos sorting algorithm

Term for the "extreme-extension" version of a straw man fallacy?



Refactor a method to using stream API


Is there a concise way to iterate over a stream with indices in Java 8?Why does Stream<T> not implement Iterable<T>?Should I always use a parallel stream when possible?Custom thread pool in Java 8 parallel streamHow to Convert a Java 8 Stream to an Array?Convert Iterable to Stream using Java 8 JDKWhat's the difference between map and flatMap methods in Java 8?Why are Java Streams once-off?How to sum a list of integers with java streams?Populate a map conditionally using streams - Java 8













8















I am currently told to count all .sql files which are hangin' out on some servers. Manually solving this very basic task is not an option, instead, I wrote some code that makes use of a SimpleFileVisitor<Path> and stores all the sql files found along with its parent path in a Map<Path, List<Path>>.



Now I want to receive the total amount of sql files found independent from their locations. I got it working with an enhanced for loop (almost the classic way):



public int getTotalAmountOfSqlFiles(Map<Path, List<Path>> sqlFilesInDirectories) 
int totalAmount = 0;

for (Path directory : sqlFilesInDirectories.keySet())
List<Path> sqlFiles = sqlFilesInDirectories.get(directory);
totalAmount += sqlFiles.size();


return totalAmount;



The question is now, how can I do the same using the stream API?



I wasn't able to get compilable code to work which isn't obviously doing the wrong thing.

The following line looks like a good idea to me, but not to the compiler, unfortunately.



totalAmount = sqlFilesInDirectories.entrySet().stream().map(List::size).sum();


The compiler says




Cannot infer type argument(s) for <R> map(Function<? super T,? extends R>




Does anyone know what I am doing wrong (and maybe provide some educated stream-API using solution)?










share|improve this question




























    8















    I am currently told to count all .sql files which are hangin' out on some servers. Manually solving this very basic task is not an option, instead, I wrote some code that makes use of a SimpleFileVisitor<Path> and stores all the sql files found along with its parent path in a Map<Path, List<Path>>.



    Now I want to receive the total amount of sql files found independent from their locations. I got it working with an enhanced for loop (almost the classic way):



    public int getTotalAmountOfSqlFiles(Map<Path, List<Path>> sqlFilesInDirectories) 
    int totalAmount = 0;

    for (Path directory : sqlFilesInDirectories.keySet())
    List<Path> sqlFiles = sqlFilesInDirectories.get(directory);
    totalAmount += sqlFiles.size();


    return totalAmount;



    The question is now, how can I do the same using the stream API?



    I wasn't able to get compilable code to work which isn't obviously doing the wrong thing.

    The following line looks like a good idea to me, but not to the compiler, unfortunately.



    totalAmount = sqlFilesInDirectories.entrySet().stream().map(List::size).sum();


    The compiler says




    Cannot infer type argument(s) for <R> map(Function<? super T,? extends R>




    Does anyone know what I am doing wrong (and maybe provide some educated stream-API using solution)?










    share|improve this question


























      8












      8








      8


      1






      I am currently told to count all .sql files which are hangin' out on some servers. Manually solving this very basic task is not an option, instead, I wrote some code that makes use of a SimpleFileVisitor<Path> and stores all the sql files found along with its parent path in a Map<Path, List<Path>>.



      Now I want to receive the total amount of sql files found independent from their locations. I got it working with an enhanced for loop (almost the classic way):



      public int getTotalAmountOfSqlFiles(Map<Path, List<Path>> sqlFilesInDirectories) 
      int totalAmount = 0;

      for (Path directory : sqlFilesInDirectories.keySet())
      List<Path> sqlFiles = sqlFilesInDirectories.get(directory);
      totalAmount += sqlFiles.size();


      return totalAmount;



      The question is now, how can I do the same using the stream API?



      I wasn't able to get compilable code to work which isn't obviously doing the wrong thing.

      The following line looks like a good idea to me, but not to the compiler, unfortunately.



      totalAmount = sqlFilesInDirectories.entrySet().stream().map(List::size).sum();


      The compiler says




      Cannot infer type argument(s) for <R> map(Function<? super T,? extends R>




      Does anyone know what I am doing wrong (and maybe provide some educated stream-API using solution)?










      share|improve this question
















      I am currently told to count all .sql files which are hangin' out on some servers. Manually solving this very basic task is not an option, instead, I wrote some code that makes use of a SimpleFileVisitor<Path> and stores all the sql files found along with its parent path in a Map<Path, List<Path>>.



      Now I want to receive the total amount of sql files found independent from their locations. I got it working with an enhanced for loop (almost the classic way):



      public int getTotalAmountOfSqlFiles(Map<Path, List<Path>> sqlFilesInDirectories) 
      int totalAmount = 0;

      for (Path directory : sqlFilesInDirectories.keySet())
      List<Path> sqlFiles = sqlFilesInDirectories.get(directory);
      totalAmount += sqlFiles.size();


      return totalAmount;



      The question is now, how can I do the same using the stream API?



      I wasn't able to get compilable code to work which isn't obviously doing the wrong thing.

      The following line looks like a good idea to me, but not to the compiler, unfortunately.



      totalAmount = sqlFilesInDirectories.entrySet().stream().map(List::size).sum();


      The compiler says




      Cannot infer type argument(s) for <R> map(Function<? super T,? extends R>




      Does anyone know what I am doing wrong (and maybe provide some educated stream-API using solution)?







      java java-8 sum java-stream






      share|improve this question















      share|improve this question













      share|improve this question




      share|improve this question








      edited yesterday









      Stefan Zobel

      2,48231931




      2,48231931










      asked yesterday









      deHaardeHaar

      2,66961729




      2,66961729






















          4 Answers
          4






          active

          oldest

          votes


















          11














          Not sure why people are involving keySet here when the required sum is only of List size contained in values. Just sum the size of all values.



          return sqlFilesInDirectories.values().stream().mapToInt(List::size).sum();


          And even the for loop version should be simply this,



          for (List<Path> list : sqlFilesInDirectories.values()) 
          totalAmount += list.size();



          As iterating over keyset and then getting value from map isn't really required and will not be better performance wise.






          share|improve this answer
































            4














            It's because in stream you're taking whole entries instead of values. This should do it:



            totalAmount = sqlFilesInDirectories.values().stream().map(List::size).sum();





            share|improve this answer






























              3














              Other answers provide the shortest way to sum all entries, but if you need the amount of scripts per Path you can use the following:



              Map<Path, Integer> amountOfFilesForPath =
              files.entrySet().stream().collect(Collectors.groupingBy(Map.Entry::getKey,
              Collectors.summingInt(value -> value.getValue().size())));


              And you can also get the total value:



              int sum = amountOfFilesForPath.values().stream().mapToInt(Integer::intValue).sum();





              share|improve this answer






























                1














                Try



                int totalAmount = sqlFilesInDirectories.keySet().stream().map(sqlFilesInDirectories::get).mapToInt(List::size).sum();





                share|improve this answer






















                  Your Answer






                  StackExchange.ifUsing("editor", function ()
                  StackExchange.using("externalEditor", function ()
                  StackExchange.using("snippets", function ()
                  StackExchange.snippets.init();
                  );
                  );
                  , "code-snippets");

                  StackExchange.ready(function()
                  var channelOptions =
                  tags: "".split(" "),
                  id: "1"
                  ;
                  initTagRenderer("".split(" "), "".split(" "), channelOptions);

                  StackExchange.using("externalEditor", function()
                  // Have to fire editor after snippets, if snippets enabled
                  if (StackExchange.settings.snippets.snippetsEnabled)
                  StackExchange.using("snippets", function()
                  createEditor();
                  );

                  else
                  createEditor();

                  );

                  function createEditor()
                  StackExchange.prepareEditor(
                  heartbeatType: 'answer',
                  autoActivateHeartbeat: false,
                  convertImagesToLinks: true,
                  noModals: true,
                  showLowRepImageUploadWarning: true,
                  reputationToPostImages: 10,
                  bindNavPrevention: true,
                  postfix: "",
                  imageUploader:
                  brandingHtml: "Powered by u003ca class="icon-imgur-white" href="https://imgur.com/"u003eu003c/au003e",
                  contentPolicyHtml: "User contributions licensed under u003ca href="https://creativecommons.org/licenses/by-sa/3.0/"u003ecc by-sa 3.0 with attribution requiredu003c/au003e u003ca href="https://stackoverflow.com/legal/content-policy"u003e(content policy)u003c/au003e",
                  allowUrls: true
                  ,
                  onDemand: true,
                  discardSelector: ".discard-answer"
                  ,immediatelyShowMarkdownHelp:true
                  );



                  );













                  draft saved

                  draft discarded


















                  StackExchange.ready(
                  function ()
                  StackExchange.openid.initPostLogin('.new-post-login', 'https%3a%2f%2fstackoverflow.com%2fquestions%2f55356349%2frefactor-a-method-to-using-stream-api%23new-answer', 'question_page');

                  );

                  Post as a guest















                  Required, but never shown

























                  4 Answers
                  4






                  active

                  oldest

                  votes








                  4 Answers
                  4






                  active

                  oldest

                  votes









                  active

                  oldest

                  votes






                  active

                  oldest

                  votes









                  11














                  Not sure why people are involving keySet here when the required sum is only of List size contained in values. Just sum the size of all values.



                  return sqlFilesInDirectories.values().stream().mapToInt(List::size).sum();


                  And even the for loop version should be simply this,



                  for (List<Path> list : sqlFilesInDirectories.values()) 
                  totalAmount += list.size();



                  As iterating over keyset and then getting value from map isn't really required and will not be better performance wise.






                  share|improve this answer





























                    11














                    Not sure why people are involving keySet here when the required sum is only of List size contained in values. Just sum the size of all values.



                    return sqlFilesInDirectories.values().stream().mapToInt(List::size).sum();


                    And even the for loop version should be simply this,



                    for (List<Path> list : sqlFilesInDirectories.values()) 
                    totalAmount += list.size();



                    As iterating over keyset and then getting value from map isn't really required and will not be better performance wise.






                    share|improve this answer



























                      11












                      11








                      11







                      Not sure why people are involving keySet here when the required sum is only of List size contained in values. Just sum the size of all values.



                      return sqlFilesInDirectories.values().stream().mapToInt(List::size).sum();


                      And even the for loop version should be simply this,



                      for (List<Path> list : sqlFilesInDirectories.values()) 
                      totalAmount += list.size();



                      As iterating over keyset and then getting value from map isn't really required and will not be better performance wise.






                      share|improve this answer















                      Not sure why people are involving keySet here when the required sum is only of List size contained in values. Just sum the size of all values.



                      return sqlFilesInDirectories.values().stream().mapToInt(List::size).sum();


                      And even the for loop version should be simply this,



                      for (List<Path> list : sqlFilesInDirectories.values()) 
                      totalAmount += list.size();



                      As iterating over keyset and then getting value from map isn't really required and will not be better performance wise.







                      share|improve this answer














                      share|improve this answer



                      share|improve this answer








                      edited yesterday

























                      answered yesterday









                      Pushpesh Kumar RajwanshiPushpesh Kumar Rajwanshi

                      10.8k21230




                      10.8k21230























                          4














                          It's because in stream you're taking whole entries instead of values. This should do it:



                          totalAmount = sqlFilesInDirectories.values().stream().map(List::size).sum();





                          share|improve this answer



























                            4














                            It's because in stream you're taking whole entries instead of values. This should do it:



                            totalAmount = sqlFilesInDirectories.values().stream().map(List::size).sum();





                            share|improve this answer

























                              4












                              4








                              4







                              It's because in stream you're taking whole entries instead of values. This should do it:



                              totalAmount = sqlFilesInDirectories.values().stream().map(List::size).sum();





                              share|improve this answer













                              It's because in stream you're taking whole entries instead of values. This should do it:



                              totalAmount = sqlFilesInDirectories.values().stream().map(List::size).sum();






                              share|improve this answer












                              share|improve this answer



                              share|improve this answer










                              answered yesterday









                              AndronicusAndronicus

                              5,91021733




                              5,91021733





















                                  3














                                  Other answers provide the shortest way to sum all entries, but if you need the amount of scripts per Path you can use the following:



                                  Map<Path, Integer> amountOfFilesForPath =
                                  files.entrySet().stream().collect(Collectors.groupingBy(Map.Entry::getKey,
                                  Collectors.summingInt(value -> value.getValue().size())));


                                  And you can also get the total value:



                                  int sum = amountOfFilesForPath.values().stream().mapToInt(Integer::intValue).sum();





                                  share|improve this answer



























                                    3














                                    Other answers provide the shortest way to sum all entries, but if you need the amount of scripts per Path you can use the following:



                                    Map<Path, Integer> amountOfFilesForPath =
                                    files.entrySet().stream().collect(Collectors.groupingBy(Map.Entry::getKey,
                                    Collectors.summingInt(value -> value.getValue().size())));


                                    And you can also get the total value:



                                    int sum = amountOfFilesForPath.values().stream().mapToInt(Integer::intValue).sum();





                                    share|improve this answer

























                                      3












                                      3








                                      3







                                      Other answers provide the shortest way to sum all entries, but if you need the amount of scripts per Path you can use the following:



                                      Map<Path, Integer> amountOfFilesForPath =
                                      files.entrySet().stream().collect(Collectors.groupingBy(Map.Entry::getKey,
                                      Collectors.summingInt(value -> value.getValue().size())));


                                      And you can also get the total value:



                                      int sum = amountOfFilesForPath.values().stream().mapToInt(Integer::intValue).sum();





                                      share|improve this answer













                                      Other answers provide the shortest way to sum all entries, but if you need the amount of scripts per Path you can use the following:



                                      Map<Path, Integer> amountOfFilesForPath =
                                      files.entrySet().stream().collect(Collectors.groupingBy(Map.Entry::getKey,
                                      Collectors.summingInt(value -> value.getValue().size())));


                                      And you can also get the total value:



                                      int sum = amountOfFilesForPath.values().stream().mapToInt(Integer::intValue).sum();






                                      share|improve this answer












                                      share|improve this answer



                                      share|improve this answer










                                      answered yesterday









                                      GlainsGlains

                                      1,166719




                                      1,166719





















                                          1














                                          Try



                                          int totalAmount = sqlFilesInDirectories.keySet().stream().map(sqlFilesInDirectories::get).mapToInt(List::size).sum();





                                          share|improve this answer



























                                            1














                                            Try



                                            int totalAmount = sqlFilesInDirectories.keySet().stream().map(sqlFilesInDirectories::get).mapToInt(List::size).sum();





                                            share|improve this answer

























                                              1












                                              1








                                              1







                                              Try



                                              int totalAmount = sqlFilesInDirectories.keySet().stream().map(sqlFilesInDirectories::get).mapToInt(List::size).sum();





                                              share|improve this answer













                                              Try



                                              int totalAmount = sqlFilesInDirectories.keySet().stream().map(sqlFilesInDirectories::get).mapToInt(List::size).sum();






                                              share|improve this answer












                                              share|improve this answer



                                              share|improve this answer










                                              answered yesterday









                                              Praveen EPraveen E

                                              55047




                                              55047



























                                                  draft saved

                                                  draft discarded
















































                                                  Thanks for contributing an answer to Stack Overflow!


                                                  • Please be sure to answer the question. Provide details and share your research!

                                                  But avoid


                                                  • Asking for help, clarification, or responding to other answers.

                                                  • Making statements based on opinion; back them up with references or personal experience.

                                                  To learn more, see our tips on writing great answers.




                                                  draft saved


                                                  draft discarded














                                                  StackExchange.ready(
                                                  function ()
                                                  StackExchange.openid.initPostLogin('.new-post-login', 'https%3a%2f%2fstackoverflow.com%2fquestions%2f55356349%2frefactor-a-method-to-using-stream-api%23new-answer', 'question_page');

                                                  );

                                                  Post as a guest















                                                  Required, but never shown





















































                                                  Required, but never shown














                                                  Required, but never shown












                                                  Required, but never shown







                                                  Required, but never shown

































                                                  Required, but never shown














                                                  Required, but never shown












                                                  Required, but never shown







                                                  Required, but never shown







                                                  -java, java-8, java-stream, sum

                                                  Popular posts from this blog

                                                  Mobil Contents History Mobil brands Former Mobil brands Lukoil transaction Mobil UK Mobil Australia Mobil New Zealand Mobil Greece Mobil in Japan Mobil in Canada Mobil Egypt See also References External links Navigation menuwww.mobil.com"Mobil Corporation"the original"Our Houston campus""Business & Finance: Socony-Vacuum Corp.""Popular Mechanics""Lubrite Technologies""Exxon Mobil campus 'clearly happening'""Toledo Blade - Google News Archive Search""The Lion and the Moose - How 2 Executives Pulled off the Biggest Merger Ever""ExxonMobil Press Release""Lubricants""Archived copy"the original"Mobil 1™ and Mobil Super™ motor oil and synthetic motor oil - Mobil™ Motor Oils""Mobil Delvac""Mobil Industrial website""The State of Competition in Gasoline Marketing: The Effects of Refiner Operations at Retail""Mobil Travel Guide to become Forbes Travel Guide""Hotel Rankings: Forbes Merges with Mobil"the original"Jamieson oil industry history""Mobil news""Caltex pumps for control""Watchdog blocks Caltex bid""Exxon Mobil sells service station network""Mobil Oil New Zealand Limited is New Zealand's oldest oil company, with predecessor companies having first established a presence in the country in 1896""ExxonMobil subsidiaries have a business history in New Zealand stretching back more than 120 years. We are involved in petroleum refining and distribution and the marketing of fuels, lubricants and chemical products""Archived copy"the original"Exxon Mobil to Sell Its Japanese Arm for $3.9 Billion""Gas station merger will end Esso and Mobil's long run in Japan""Esso moves to affiliate itself with PC Optimum, no longer Aeroplan, in loyalty point switch""Mobil brand of gas stations to launch in Canada after deal for 213 Loblaws-owned locations""Mobil Nears Completion of Rebranding 200 Loblaw Gas Stations""Learn about ExxonMobil's operations in Egypt""Petrol and Diesel Service Stations in Egypt - Mobil"Official websiteExxon Mobil corporate websiteMobil Industrial official websiteeeeeeeeDA04275022275790-40000 0001 0860 5061n82045453134887257134887257

                                                  Frič See also Navigation menuinternal link

                                                  Identify plant with long narrow paired leaves and reddish stems Planned maintenance scheduled April 17/18, 2019 at 00:00UTC (8:00pm US/Eastern) Announcing the arrival of Valued Associate #679: Cesar Manara Unicorn Meta Zoo #1: Why another podcast?What is this plant with long sharp leaves? Is it a weed?What is this 3ft high, stalky plant, with mid sized narrow leaves?What is this young shrub with opposite ovate, crenate leaves and reddish stems?What is this plant with large broad serrated leaves?Identify this upright branching weed with long leaves and reddish stemsPlease help me identify this bulbous plant with long, broad leaves and white flowersWhat is this small annual with narrow gray/green leaves and rust colored daisy-type flowers?What is this chilli plant?Does anyone know what type of chilli plant this is?Help identify this plant