Skip to main content

What are the main uses of the Stream API in Java 8?

 Stream is a feature in Java 8. Stream supporting Internal iteration which will provides several features such as sequential and parallel execution, filtering based on the given criteria, mapping etc.

Java 8 Stream support sequential as well as parallel processing, parallel processing can be very helpful in achieving high performance for large collections.

All the Java Stream API interfaces and classes are in the java.util.stream package. Since we can use primitive data types such as int, long in the collections using auto-boxing and these operations could take a lot of time, there are specific classes for primitive types – IntStreamLongStream and DoubleStream.


For Example, you might want to create a collection of employees to represent a company's staff information. Then, you might want to process the whole collection to find out how many days that employee works for the company.

First, we may iterate over the collections to process some works such as “finding” (find the employee with the highest salary) or “grouping” (group all employees in the IT department). These operations are similar to SQL-like operations.

  1. SELECT max(salary) FROM Employee 

As you already know, the above query will return the largest value (salary) of the selected column (Employee). We don't need to specify how to implement the maximum operation, just tell what we expect it to be done. Why can’t we do something similar with collections? How many times do you find yourself reimplementing these operations using loops over and over again?

Second, how can we treat a large collection efficiently? Do we make sure that we can process it appropriately? Ideally, to speed up the processing, you want to leverage multicore architectures. However, writing parallel code is harder than you can think of.

To resolve 2 issues mentioned above, 

Stream API may help you process input data in a declarative way similar to SQL. Stream API in Java 8 will resolve such above issues and leverage multicore architecture without the need to write any particular piece of code.

java.util.stream introduces several operations(filtersortedmapcollect, ...) to process elements in sequence. Streams are wrappers for collections and arrays. They wrap an existing collection to support operations expressed with Lambda Expression, so you decide what you want to do instead of how to do it.

Comments

Popular posts from this blog

What is Amazon Web Services (AWS)?

 Amazon Web Services Amazon Web Services is a cloud computing platform provided by Amazon. The AWS offers all three service models such as Software as a Service (SaaS), Infrastructure as a Service (IAAS), and Platform as a Service (PaaS). There are more services which comprise the Amazon Web Services including Amazon Elastic Compute Cloud (EC2) which provides virtual servers, Amazon Simple Storage Service (S3) which provides scalable storage for backups, analytics. Then there are other services such as Amazon relational database management system, DynamoDB, AWS Migration hub, and more. AWS provides services in almost every category from mobile development to data analytics. Benefits of using Amazon Web Services: AWS gives access to organizations to use programming models , database and operating system. It provides a cost effective service in which you only have to pay for what you use. Applications can be deployed in multiple regions with just a few clicks. ...

Which is best, Java or Python in 2020?

Depends what you want to do. You  can  use either language for almost anything, but they definitely have different strengths and weaknesses that can help you decide which one is better for what you are doing. Python is good for: Numeric computing and AI All kinds of science and academic stuff (including natural language processing) Rapid prototyping Website backends Learning and teaching programming concepts all kinds of workflow scripting and other small programs for getting simple jobs done. interfacing with C libraries. Java is good for: Creating and distributing applications (on mobile and desktop) high-performance network backends. creating robust, reliable software at a large scale, especially in teams. implementing more foundational software systems like databases (though you might find C++ a better match for that) As a starting point to learning the JVM and leveraging it for a number of other interesting languages it hosts like Kotlin, Scala, Cloju...

What is Java Unit testing, and how do I learn it...

What is Java Unit testing, and how do I learn it... Java Unit testing is when you create small tests to verify that small bits of your code are working as “units.” Typically you write these tests in Java itself. In each test, you might get the system into a certain state, then you interact with the system to exercise the behavior you want to test. You finally verify whether or not the system did what you expected. A primary goal is to reduce the number of defects that you integrate into the rest of the source base. You’ll find numerous tutorial articles if you search. Most people use JUnit, a simple tool that you’ll find in Eclipse or IDEA.