Tuesday, 26 September 2017

Enum ordinal() method

Java.lang.Enum.ordinal() Method

The java.lang.Enum.ordinal() method returns the ordinal of this enumeration constant (its position in its enum declaration, where the initial constant is assigned an ordinal of zero).

Declaration
Following is the declaration for java.lang.Enum.ordinal() method

public final int ordinal()

Parameters
NA

Return Value
This method returns the ordinal of this enumeration constant.

Exception
NA

Example
The following example shows the usage of java.lang.Enum.ordinal() method.

enum Country{
   India(9), Nepal(8),Shrilanka(5);
   int gdp;
   Mobile(int gdp) {
      this.gdp= gdp;
   }
   int getGdp() {
      return gdp;
   } 
}

public class EnumDemo {

   public static void main(String args[]) {
      System.out.println("CellPhone List:");
      for(Country c : Country.values()) {
         System.out.println("Gdp of"+c+ "is"+ c.getGdp() );
      }
      Country c = Country.India;
      System.out.println("The ordinal is = " + c.ordinal());
      System.out.println("Country= " + c.name());                      
   }
}

Default and Static Methods in Interface

Default and Static Methods in Interface!

Before Java 8, interfaces could have only public abstract methods. It was not possible to add new functionality to the existing interface without forcing all implementing classes to create an implementation of the new methods, nor it was possible to create interface methods with an implementation.

Starting with Java 8, interfaces can have static and default methods that, despite being declared in an interface, have a defined behavior.

Static Method

Consider the following method of the interface (let’s call this interface Person):

static String nationality() {
    return "Indian";
}

The static nationality() method is available only through and inside of an interface. It can’t be overridden by an implementing class.

To call it outside the interface the standard approach for static method call should be used:

String nationality = Person.nationality();

Default Method
Default methods are declared using the new default keyword. These are accessible through the instance of the implementing class and can be overridden.

Let’s add a default method to our Person interface, which will also make a call to the static method of this interface:

default String getRating() {
    return "Good ";
}

Assume that this interface is implemented by the class Employee. For executing the default method an instance of this class should be created:

Person employee = new Employee();
String overview = employee .getRating();

Java 8 features

Java 8 new features

  1. forEach() method in Iterable interface
  2. default and static methods in Interfaces
  3. Functional Interfaces and Lambda Expressions
  4. Java Time API
  5. Collection API improvements
  6. Java IO improvements
  7. Miscellaneous Core API improvements
  8. Concurrency API improvements
  9. Java Stream API for Bulk Data Operations

forEach() method in Iterable interface

Remember ConcurrentModificationException if iterator is not used properly, no need to worry for it .
Java 8 has introduced forEach method in java.lang.Iterable interface so that while writing code we focus on business logic only. forEach method takes java.util.function.Consumer object as argument, so it helps in having our business logic at a separate location that we can reuse.

List<String> names = new ArrayList<>();
items.add("Ashwin");
items.add("Samar");
items.add("Omer");
items.add("Sachin");
items.add("Sandeep");

//lambda
items.forEach(item->System.out.print(item +"\t"));
//Output: Ashwin Samar Omer Sachin Sandeep

//Checking condition
items.forEach(item->{
    if("Ashwin".equals(item)){
        System.out.println(item);
    }
});
//Output : Ashwin

//method reference
items.forEach(System.out::println);
//Output: Ashwin Samar Omer Sachin Sandeep 

//Using Stream and filter
items.stream()
    .filter(s->s.contains("Samar"))
    .forEach(System.out::println);

//Output: Samar

default and static methods in Interfaces

Before Java 8, interfaces could have only public abstract methods. It was not possible to add new functionality to the existing interface without forcing all implementing classes to create an implementation of the new methods, nor it was possible to create interface methods with an implementation.

Starting with Java 8, interfaces can have static and default methods that, despite being declared in an interface, have a defined behavior.

Static Method
Consider the following method of the interface (let’s call this interface Person):

static String nationality() {
    return "Indian";
}

The static producer() method is available only through and inside of an interface. It can’t be overridden by an implementing class.
To call it outside the interface the standard approach for static method call should be used

String nationality = Person.nationality();

Wednesday, 5 July 2017

Java 7 new Features

New Features of Java 7

  1. String in switch statement
    Before JDK 7, only integral types can be used as selector for switch-case statement. In JDK 7, you can use a String object as the selector. For example,

    String state= “state”;
    switch (state) {
    case “NEW”: System.out.println(“The thread is in ready state”); break;
    case “RUNNABLE”: System.out.println(“The thread is in RUNNABLE state”); break;
    case “BLOCKED”: System.out.println(“The thread is in BLOCKEDstate”); break;
    case “WAITING”: System.out.println(“The thread is in WAITING state”) ; break;
    default: System.out.println(“Invalid State”);
    }
    equals() and hashcode() method from java.lang.String is used in comparison, which is case-sensitive

    2.Type inference
    Before JDK 1.7 introduce a new operator <<, known as diamond operator to making type inference available for constructors as well. Prior to Java 7, type inference is only available for methods, and Joshua Bloch has rightly predicted in Effective Java 2nd Edition, it’s now available for constructor as well.
    Prior JDK 7, you type more to specify types on both left and right hand side of object creation expression, but now it only needed on left hand side, as shown in below example.

    Prior JDK 7

    Map<String, List<String>> students =  new   HashMap<String, List<String>>();
    List<Integer> integerList = new ArrayList<Integer>();
    

    In JDK 7

    Map<String, List<String>> students =  new HashMap<>();
    List<Integer> integerList = new ArrayList<>();
    

    3.Automatic Resource Management
    Before JDK 7, we need to use a finally block, to ensure that a resource is closed regardless of whether the try statement completes normally or abruptly, for example while reading files and streams, we need to close them into finally block, which result in lots of boiler plate and messy code, as shown below :

    public static void main(String args[]) {
            FileInputStream fin = null;
            BufferedReader br = null;
            try {
                fin = new FileInputStream("somedata.xml");
                br = new BufferedReader(new InputStreamReader(fin));
                if (br.ready()) {
                    String line1 = br.readLine();
                    System.out.println(line1);
                }
            } catch (FileNotFoundException ex) {
                System.out.println("somedata.xml is not found");
            } catch (IOException ex) {
                System.out.println("Can't read the file");
            } finally {
                try {
                    if (fin != null) fin.close();
                    if (br != null) br.close();
                } catch (IOException ie) {
                    System.out.println("Failed to close files");
                }
            }
        }
    

Now in Java 7, you can use try-with-resource feature to automatically close resources, which implements AutoClosable and Closeable interface e.g. Streams, Files, Socket handles, database connections etc. JDK 7 introduces a try-with-resources statement, which ensures that each of the resources in try(resources) is closed at the end of the statement by calling close() method of AutoClosable.

public static void main(String args[]) {
   try (FileInputStream fin = new FileInputStream("somedata.xml");
  BufferedReader br = new BufferedReader(new InputStreamReader(fin));) {
  if (br.ready()) {
   String line1 = br.readLine();
   System.out.println(line1);
  }
 } catch (FileNotFoundException ex) {
  System.out.println("Info.xml is not found");
 } catch (IOException ex) {
  System.out.println("Can't read the file");
 }
}

4.Fork Join Framework
The fork/join framework is an implementation of the ExecutorService interface that allows you to take advantage of multiple processors available in modern servers. It is designed for work that can be broken into smaller pieces recursively. The goal is to use all the available processing power to enhance the performance of your application. As with any ExecutorService implementation, the fork/join framework distributes tasks to worker threads in a thread pool. The fork join framework is distinct because it uses a work-stealing algorithm, which is very different than producer consumer algorithm. Worker threads that run out of things to do can steal tasks from other threads that are still busy. The centre of the fork/join framework is the ForkJoinPool class, an extension of the AbstractExecutorService class. ForkJoinPool implements the core work-stealing algorithm and can execute ForkJoinTask processes. You can wrap code in a ForkJoinTask subclass like RecursiveTask (which can return a result) or RecursiveAction.

5.Underscore in Numeric literals
In JDK 7, we could insert underscore(s) ‘_’ in between the digits in an numeric literals (integral and floating-point literals) to improve readability. This is especially valuable for people who uses large numbers in source files, may be useful in finance and computing domains. For example,

int billion = 1_000_000_000;  // 10^9
long creditCardNumber =  1234_4567_8901_2345L; //16 digit number
long ssn = 777_99_8888L;
double pi = 3.1415_9265;
float  pif = 3.14_15_92_65f;

You can put underscore at convenient points to make it more readable, for examples for large amounts putting underscore between three digits make sense, and for credit card numbers, which are 16 digit long, putting underscore after 4th digit make sense, as they are printed in cards. By the way remember that you cannot put underscore, just after decimal number or at the beginning or at the end of number. For example, following numeric literals are invalid, because of wrong placement of underscore:

 double pi = 3._1415_9265; // underscore just after decimal point 
 long creditcardNum = 1234_4567_8901_2345_L; //underscore at the end of number 
 long ssn = _777_99_8888L; //undersocre at the beginning

6.Catching Multiple Exception Type in Single Catch Block

Java 7 Feature Revisited BookIn JDK 7, a single catch block can handle more than one exception types.

For example, before JDK 7, you need two catch blocks to catch two exception types although both perform identical task:

try {

   ......

} catch(ClassNotFoundException ex) {
   ex.printStackTrace();
} catch(SQLException ex) {
   ex.printStackTrace();
}

In JDK 7, you could use one single catch block, with exception types separated by ‘|’.

try {
   ......

} catch(ClassNotFoundException|SQLException ex) {

   ex.printStackTrace();
}

By the way, just remember that Alternatives in a multi-catch statement cannot be related by sub classing. For example a multi-catch statement like below will throw compile time error :

try {
   ......

} catch (FileNotFoundException | IOException ex) {

   ex.printStackTrace();

}

Alternatives in a multi-catch statement cannot be related by sub classing, it will throw error at compile time :
java.io.FileNotFoundException is a subclass of alternative java.io.IOException
at Test.main(Test.java:18)

7.Binary Literals with prefix “0b”

In JDK 7, you can express literal values in binary with prefix ‘0b’ (or ‘0B’) for integral types (byte, short, int and long), similar to C/C++ language. Before JDK 7, you can only use octal values (with prefix ‘0’) or hexadecimal values (with prefix ‘0x’ or ‘0X’).

int mask = 0b01010000101;

or even better

int binary = 0B0101_0000_1010_0010_1101_0000_1010_0010;

8.Java NIO 2.0
Java SE 7 introduced java.nio.file package and its related package, java.nio.file.attribute, provide comprehensive support for file I/O and for accessing the default file system. It also introduced the Path class which allow you to represent any path in operating system. New File system API complements older one and provides several useful method checking, deleting, copying, and moving files. for example, now you can check if a file is hidden in Java. You can also create symbolic and hard links from Java code. JDK 7 new file API is also capable of searching for files using wild cards. You also get support to watch a directory for changes.

9.G1 Garbage Collector
JDK 7 introduced a new Garbage Collector known as G1 Garbage Collection, which is short form of garbage first. G1 garbage collector performs clean-up where there is most garbage. To achieve this it split Java heap memory into multiple regions as opposed to 3 regions in the prior to Java 7 version (new, old and permgen space). It’s said that G1 is quite predictable and provides greater through put for memory intensive applications.

10.More Precise Rethrowing of Exception
The Java SE 7 compiler performs more precise analysis of re-thrown exceptions than earlier releases of Java SE. This enables you to specify more specific exception types in the throws clause of a method declaration. before JDK 7, re-throwing an exception was treated as throwing the type of the catch parameter. For example, if your try block can throw ParseException as well as IOException. In order to catch all exceptions and rethrow them, you would have to catch Exception and declare your method as throwing an Exception. This is sort of obscure non-precise throw, because you are throwing a general Exception type (instead of specific ones) and statements calling your method need to catch this general Exception. This will be more clear by seeing following example of exception handling in code prior to Java 1.7

public void obscure() throws Exception{
    try {
        new FileInputStream("abc.txt").read();
        new SimpleDateFormat("ddMMyyyy").parse("12-03-2014");        
    } catch (Exception ex) {
        System.out.println("Caught exception: " + ex.getMessage());
        throw ex;
    }
}

From JDK 7 onwards you can be more precise while declaring type of Exception in throws clause of any method. This precision in determining which Exception is thrown from the fact that, If you re-throw an exception from a catch block, you are actually throwing an exception type which:

1) your try block can throw,
2) has not handled by any previous catch block, and
3) is a subtype of one of the Exception declared as catch parameter

This leads to improved checking for re-thrown exceptions. You can be more precise about the exceptions being thrown from the method and you can handle them a lot better at client side, as shown in following example :

public void precise() throws ParseException, IOException {
    try {
        new FileInputStream("abc.txt").read();
        new SimpleDateFormat("ddMMyyyy").parse("12-03-2014");        
    } catch (Exception ex) {
        System.out.println("Caught exception: " + ex.getMessage());
        throw ex;
    }
}

The Java SE 7 compiler allows you to specify the exception types ParseException and IOException in the throws clause in the preciese() method declaration because you can re-throw an exception that is a super-type of any of the types declared in the throws, we are throwing java.lang.Exception, which is super class of all checked Exception. Also in some places you will see final keyword with catch parameter, but that is not mandatory any more.