Is there naming convention for methods that return Stream? The only mention I found is this answer on S.O (last paragraph), but I don't see what is it based on.
stream() − Returns a sequential stream considering collection as its source. parallelStream() − Returns a parallel Stream considering collection as its source.
Stream provides predefined methods to deal with the logic you implement. In the following example, we are iterating, filtering and passed a limit to fix the iteration. import java.util.stream.*; public class JavaStreamExample { public static void main(String[] args){
Return Streams means the streams, substances and byproducts provided by the Customer to the Service Provider in connection with the provision by the Service Provider to the Customer of the Site Services described in Service Schedules A.
So how does it work internally? It's actually pretty simple. Java uses trySplit method to try splitting the collection in chunks that could be processed by different threads. In terms of the execution plan, it works very similarly, with one main difference.
Since I wrote that paragraph I feel compelled to answer. :-)
Suppose you have a class that represents an aggregation of things of a single type, and you want to return a Stream
of them to the caller.
If it's totally unambiguous as to what you're returning, you might just as well call the method stream()
. There are a lot of methods in the JDK named stream()
that return a stream of the obvious type.
Sometimes what you're returning is different representations of the same thing, or different kinds of things, or whatever. In that case there does seem to be a convention to choose a plural noun that represents the type of things being returned in the stream.
To see these, look in the Javadoc and click the Use link in the top navigation bar. This will take you to a cross-reference page. Look for all methods that have return values of the type you're interested in.
For example, see the Use pages for Stream
, IntStream
, LongStream
, and DoubleStream
. There are lots of methods named stream()
that return streams. But there are also:
java.io.BufferedReader.lines()
java.lang.CharSequence.chars()
java.lang.CharSequence.codePoints()
java.nio.CharBuffer.chars()
java.nio.file.File.lines()
java.util.Random.ints()
java.util.Random.longs()
java.util.Random.doubles()
java.util.SplittableRandom.ints()
java.util.SplittableRandom.longs()
java.util.SplittableRandom.doubles()
java.util.concurrent.ThreadLocalRandom.ints()
java.util.concurrent.ThreadLocalRandom.longs()
java.util.concurrent.ThreadLocalRandom.doubles()
Of course, there are a lot of methods that don't conform to this. The NIO file utility class has Files.find()
, Files.list()
, and Files.walk()
. A stream of results from splitting a string is returned by java.util.regex.Pattern.splitAsStream
. I don't think anybody likes the AsStream
suffix but then again, nobody could think of anything better. On the other hand, a proposed JDK 9 enhancement to get a stream of regex match results will be named Matcher.results()
.
If you love us? You can donate to us via Paypal or buy me a coffee so we can maintain and grow! Thank you!
Donate Us With