Showing posts with label Java. Show all posts
Showing posts with label Java. Show all posts

Thursday, August 1, 2019

Combinations of all numbers in List

Recently I was asked this seemingly innocent problem, given an array of numbers, generate all combination of indices of all lengths possible. For example, if there is an array of length 3, the result should be combinations of all indices of length 1, 2 and 3. The answer should be like below.

{{0},{1},{2},{0,1},{0,2},{1,2},{0,1,2}

The problem at first seemed extremely simple, but as I got down to writing code for it, it was clear very quickly that it is not that simple a problem. The final solution is not very complex. Basically, we start with all the sets of length 1 and then for every higher length, we create elements with all the indices prefixed to all the solutions of a lower length. Here is a solution that I finally came up with.


Wednesday, September 19, 2018

Finally clause in Java

Recently I was asked this question; "Is finally guaranteed to be always called in Java programs". "What are the cases when finally will not be called".

My first answer was it will always be called, of course, that was a simplistic answer and once I thought about it for a while some more thoughts came to my mind.

  1. In a healthy VM, finally is guaranteed to be called always. At least this is what I thought.
  2. If somebody abruptly terminates the node the JVM really will have no time to call finally
  3. If somebody kills the JVM with a SIGKILL, the JVM will have no time to call finally.
Now I started thinking about, is there a scenario when finally will not be called even if conditions 2 & 3 did not occur.

One of the calls that comes to mind is System.exit(), its behavior is very similar to abruptly terminate a JVM so I was keen to understand if it will call finally. As I looked at the finally specification, I found the following statement.

The finally block always executes when the try block exits. This ensures that the finally block is executed even if an unexpected exception occurs. 
When one looks at System.exit(), the following information is found.

Terminates the currently running Java Virtual Machine. The argument serves as a status code; by convention, a nonzero status code indicates abnormal termination. This method calls the exit method in class Runtime. This method never returns normally.
The key point here is that System.exit() never returns. If it is never returned then the try block will get no chance of getting exited. If try block is not getting exited, it the JVM can't call finally. Finally, as they say, proof of the pudding is in eating so I decided to try it with the latest VM.
public class FinallyCode {

  public static void main(String[] args) {
    try {
      System.out.println("Try is terminating normally.");
    }
    finally {
      System.out.println("Finally is called.");
    }
  }
}

And the output is as below.
Try is terminating normally.
Finally is called.
As we can see, this is the expected behavior, once the normal flow of try block is complete, the code in finally is called.
The next bit is when there is an exception in the normal flow of try block.

public class FinallyCode {

  public static void main(String[] args) {
    try {
      System.out.println("Try is terminating after throwing NullPointerException.");
      throw new NullPointerException();
    }
    finally {
      System.out.println("Finally is called.");
    }
  }
}

And the output is as below.
Try is terminating after throwing NullPointerException.
Finally is called.
Exception in thread "main" java.lang.NullPointerException
 at FinallyCode.main(FinallyCode.java:6)
We can see that when an exception is thrown in the flow of try block, the finally is called on the try block exit.
public class FinallyCode {

  public static void main(String[] args) {
    try {
      System.out.println("Try is terminating after calling System.exit().");
      System.exit(0);;
    }
    finally {
      System.out.println("Finally is called.");
    }
  }
}

And the output is as below.
Try is terminating after calling System.exit().
Just to be doubly sure, I tried with the error code in System.exit as another number apart from 0.
public class FinallyCode {

  public static void main(String[] args) {
    try {
      System.out.println("Try is terminating after calling System.exit().");
      System.exit(1);;
    }
    finally {
      System.out.println("Finally is called.");
    }
  }
}

And the output is as below.
Try is terminating after calling System.exit().
That leaves us to a small matter of what one needs to do when System.exit is called. Java defines a shutdown hook that can call a user-defined function in case VM is terminating.

A shutdown hook is simply an initialized but unstarted thread. When the virtual machine begins its shutdown sequence it will start all registered shutdown hooks in some unspecified order and let them run concurrently. When all the hooks have finished it will then run all uninvoked finalizers if finalization-on-exit has been enabled. Finally, the virtual machine will halt. Note that daemon threads will continue to run during the shutdown sequence, as will non-daemon threads if shutdown was initiated by invoking the exit method.
Once the shutdown sequence has begun it can be stopped only by invoking the halt method, which forcibly terminates the virtual machine.
Once the shutdown sequence has begun it is impossible to register a new shutdown hook or de-register a previously-registered hook. Attempting either of these operations will cause an IllegalStateException to be thrown.
So, how do we define a shutdown hook? Look at the code below.
public class FinallyCode {

  public static void main(String[] args) {
    try {
      Runtime.getRuntime().addShutdownHook(new Thread() {
        public void run() {
          System.out.println("Shutdown hook is called.");
        }
      });
      System.out.println("Try is terminating after calling System.exit().");
      System.exit(5);;
    }
    finally {
      System.out.println("Finally is called.");
    }
  }
}
The output is as below.
Try is terminating after calling System.exit().
Shutdown hook is called.

So the learnings from this small experiment are as follows.


  1. When the virtual machine is working normally, the finally is guaranteed to be called unless System.exit is called in the normal flow of the execution.
  2. When System.exit is called, since the function never returns, finally is not called.
  3. If the JVM is terminated through SIGKILL or through hardware reset, the finally is not called.

Tuesday, September 9, 2014

Why I think Java is bad for computer industry

I have felt this for quite a long time and after multiple events that have happened in past, I have come to the conclusion that java should not be the first language of anybody who intends to learn programming. Even the regular java programmer should take their time off and code in some other language once in a while.

Why am I saying this. In last many years, I have run a programming competition for the employees of the companies where I have been working in. These are individuals with significant experience in programming. We generally allow people to code in C/C++ and Java.

Most of the problems that we design for these competitions have a standard statement written in them. 
The input is read from standard input till EOF and the output should be written to standard output.

Almost every year I am asked clarifications related to this statement in many different forms.

  1. My program reads from a file standard-input.txt and writes to standard-output.txt
  2. My program reads one line at a time and then you have to run it again 
  3. Standard input doesn't have EOF
Almost always these clarifications come from experienced Java programmers. This leads me to believe that people who start programming in languages that have extremely rich set of libraries forget the basic constructs of language, programming and operating system. These are some basic constructs that I would expect everybody would know Even otherwise, it is just a simple google query away. Since most of these people are experienced programmer, their presumption is that the question must have a typo and then don't bother looking it up.

There, it is off my chest now. I can breathe properly.