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

Java RoadMap

 

Dealing with Passwords in Java Applications: 5 Best Practices You Should Follow

 In modern Java applications—whether core Java applications or enterprise-level web applications—working with passwords is inevitable. Passwords are sensitive pieces of information, just like Social Security Numbers (SSNs), and if you’re handling real human data in systems such as online banking or healthcare portals, it’s critical to implement best practices for dealing with passwords securely. Below, I’ll share five essential best practices that I’ve learned and recommend for managing passwords, particularly when you are handling authentication and authorization. While these tips are a good starting point, be sure to tailor them to your application’s requirements and security policies. 1) Use SSL/TLS to Transfer Username and Password When users send passwords over the network, it is crucial to use SSL/TLS to encrypt the communication. This ensures that sensitive information is protected from eavesdroppers. Tools like LDAP and Active Directory are commonly used for storing usern...

What is JDK, JRE and JVM?

What are JDK, JRE, and JVM: JDK :- Java Development Kit (in short JDK) is Kit which provides the environment to Develop and execute(run ) the Java program. For eg. You(as Java Developer) are developing an accounting application on your machine, so what do you going to need into your machine to develop and run this desktop app? You are going to need  J-D-K  for that purpose for this you just need to go to the official website of sun or oracle to download the latest version of JDK into your machine. Hence, JDK is a kit(or package) which includes two things i) Development Tools(to provide an environment to develop your java programs) and ii) JRE (to execute your java program). JDK is only used by Java Developers. JRE: - Java Runtime Environment (to say JRE) is an installation package which provides an environment to only run(not develop) the java program(or application)onto your machine. For eg(continuing with the same example) after developing your accounting ap...