Skip to main content

Sorting Employees by Salary in Reverse Order using Java 8 Streams

Question: How can we sort a list of employees by their salary in reverse order using Java 8 streams?

Answer:

  1. Create an Employee Class:

    • First, create an Employee class that includes properties like name and salary. This class will represent the structure of your employee objects.
    java
    public class Employee { private String name; private double salary; public Employee(String name, double salary) { this.name = name; this.salary = salary; } // Getters and setters for name and salary (not shown for brevity) }
  2. Create a List of Employees:

    • Next, create a list of Employee objects to work with. Populate this list with employee data.
    java
    List<Employee> employees = new ArrayList<>(); employees.add(new Employee("Alice", 60000)); employees.add(new Employee("Bob", 75000)); employees.add(new Employee("Charlie", 50000)); employees.add(new Employee("David", 90000));
  3. Sort Employees by Salary in Reverse Order:

    • To sort employees by salary in reverse order, you can use Java 8 streams. Here's the code for this step:
    java
    List<Employee> sortedEmployees = employees.stream() .sorted(Comparator.comparing(Employee::getSalary).reversed()) .collect(Collectors.toList());
    • In this code, we use the stream() method to convert the list of employees into a stream.
    • The sorted method is used to perform the sorting.

    • We pass a comparator that compares employees based on their salary in reverse order using Comparator.comparing(Employee::getSalary).reversed().

    • Finally, we collect the sorted employees back into a list using collect(Collectors.toList()).

    • Print the Sorted List:
    • After sorting, you can print the sorted list to see the results.
    java
    sortedEmployees.forEach(employee -> System.out.println("Name: " + employee.getName() + ", Salary: " + employee.getSalary()));

Example Code:

java
import java.util.ArrayList; import java.util.Comparator; import java.util.List; import java.util.stream.Collectors; public class EmployeeSortingExample { public static void main(String[] args) { // Create a list of employees List<Employee> employees = new ArrayList<>(); employees.add(new Employee("Alice", 60000)); employees.add(new Employee("Bob", 75000)); employees.add(new Employee("Charlie", 50000)); employees.add(new Employee("David", 90000)); // Sort employees by salary in reverse order List<Employee> sortedEmployees = employees.stream() .sorted(Comparator.comparing(Employee::getSalary).reversed()) .collect(Collectors.toList()); // Print the sorted list sortedEmployees.forEach(employee -> System.out.println("Name: " + employee.getName() + ", Salary: " + employee.getSalary())); } }

Sample Output:

output
Name: David, Salary: 90000.0 Name: Bob, Salary: 75000.0 Name: Alice, Salary: 60000.0 Name: Charlie, Salary: 50000.0

This code example demonstrates how to sort a list of employees by their salaries in reverse order using Java 8 streams, providing you with a sorted list of employees based on their salary, from highest to lowest.

Comments

Popular posts from this blog

Using Java 8 Streams to Find the Second-Highest Salary in an Employee List

To find the second-highest salary from a list of employees using Java 8 streams, you can follow these steps: Create a list of employees with their salaries. Use Java 8 streams to sort the employees by salary in descending order. Skip the first element (which is the employee with the highest salary). Get the first element of the remaining stream (which is the employee with the second-highest salary). Example code: java import java.util.ArrayList; import java.util.List; class Employee { private String name; private double salary; public Employee (String name, double salary) { this .name = name; this .salary = salary; } public double getSalary () { return salary; } } public class SecondHighestSalary { public static void main (String[] args) { List<Employee> employees = new ArrayList <>(); employees.add( new Employee ( "John" , 60000.0 )); employees.add( new Employe...

Top 20 Exception Handling Interview Questions and Answers for Experienced Java Developers

Introduction: Exception handling is a crucial aspect of Java development, ensuring robust and error-tolerant code. Experienced Java developers are expected to have a deep understanding of exception handling mechanisms. In this blog post, we'll explore the top 20 interview questions related to exception handling, accompanied by detailed answers and sample code snippets to help you prepare for your next Java interview. 1. What is an exception in Java? An exception is an event that disrupts the normal flow of a program. In Java, exceptions are objects that represent errors or abnormal situations during runtime. java try { // Code that may throw an exception } catch (ExceptionType e) { // Code to handle the exception } 2. Differentiate between checked and unchecked exceptions. Checked exceptions are checked at compile-time, and the programmer is forced to either catch them or declare that the method throws them. Unchecked exceptions, on the other hand, are not checked at ...

Java Data Structures and Algorithms: A Practical Guide with Examples and Top Interview Questions"

Data Structures and Algorithms in Java Understanding Data Structures ArrayList When to Use: Use ArrayList when you need a dynamic array that can grow or shrink in size. It's efficient for random access but less efficient for frequent insertions and deletions. Example Code: java List<String> arrayList = new ArrayList <>(); arrayList.add( "Java" ); arrayList.add( "Data Structures" ); arrayList.add( "Algorithms" ); LinkedList When to Use: LinkedList is suitable for frequent insertions and deletions. It provides better performance than ArrayList in scenarios where elements are frequently added or removed from the middle of the list. Example Code: java LinkedList<String> linkedList = new LinkedList <>(); linkedList.add( "Java" ); linkedList.add( "Data Structures" ); linkedList.add( "Algorithms" ); HashMap When to Use: Use HashMap for fast retrieval of data based on a key. It is efficient for loo...

Subscribe to get new posts

Name

Email *

Message *