Top 10 Tricky Java interview questions and Answers (original) (raw)
10 Tricky Java interview question - Answered
Here is my list of 10 tricky Java interview questions, Though I have prepared and shared a lot of difficult core Java interview questions and answers, I have chosen them as the Top 10 tricky questions because you can not guess answers to these tricky Java questions easily, you need some subtle details of Java programming language to answer these questions.
1. Question: What does the following Java program print?
public class Test { public static void main(String[] args) { System.out.println(Math.min(Double.MIN_VALUE, 0.0d)); } }
Answer: This question is tricky because unlike the Integer, where MIN_VALUE is negative, both the MAX_VALUE and MIN_VALUE of the Double class are positive numbers. The Double.MIN_VALUE is 2^(-1074), a double constant whose magnitude is the least among all double values.
So unlike the obvious answer, this program will print 0.0 because of Double.MIN_VALUE is greater than 0. I have asked this question to a Java developer having experience of up to 3 to 5 years and surprisingly almost 70% of candidates got it wrong.
If you are not familiar with essential Java data types and wrapper classes like Double and Float then I highly recommend you to join a comprehensive Java course like The Complete Java Masterclass on Udemy to learn them, they are very very important not just for interviews but also for day to day Java work.
2. What will happen if you put the return statement or System.exit () on the try or catch block? Will finally block execute?
This is a very popular tricky Java question, and it's tricky because many programmers think that no matter what, but the finally block will always execute. This question challenge that concept by putting a return statement in the try or catch block or calling System.exit() from try or catch block.
The answer to this tricky question in Java is that finally, the block will execute even if you put a return statement in the try block or catch block but finally block won't run if you call System.exit() from the try or catch block.
3. Question: Can you override a private or static method in Java?
Another popular Java tricky question, As I said method overriding is a good topic to ask trick questions in Java. Anyway, you can not override a private or static method in Java, if you create a similar method with the same return type and same method arguments in child class then it will hide the superclass method, this is known as method hiding.
Similarly, you cannot override a private method in subclass because it's not accessible there, what you do is create another private method with the same name in the child class.
4. Question: What do the expression 1.0 / 0.0 will return? will it throw Exception? any compile-time error?
Answer: This is another tricky question from the Double class. Though Java developer knows about the double primitive type and Double class, while doing floating-point arithmetic they don't pay enough attention to Double.INFINITY, NaN, and -0.0 and other rules that govern the arithmetic calculations involving them.
The simple answer to this question is that it will not throw ArithmeticExcpetion and return Double.INFINITY.
Also, note that the comparison x == Double.NaN always evaluates to false, even if x itself is a NaN. To test if x is a NaN, one should use the method called Double.isNaN(x) to check if the given number is NaN or not. If you know SQL, this is very close to NULL there.
Btw, If you are running out of time for your interview preparation, you can also check out my book Grokking the Java Interview for more of such popular questions,
5. Does Java support multiple inheritances?
This is the trickiest question in Java if C++ can support direct multiple inheritances then why not Java is the argument Interviewer often give. The answer to this question is much more subtle than it looks like, because Java does support multiple inheritances of Type by allowing an interface to extend other interfaces, what Java doesn't support is multiple inheritances of implementation.
This distinction also gets blurred because of the default method of Java 8, which now provides Java, multiple inheritances of behavior as well. See why multiple inheritances are not supported in Java to answer this tricky Java question.
6. What will happen if we put a key object in a HashMap which is already there?
This tricky Java question is part of another frequently asked question, How HashMap works in Java. HashMap is also a popular topic to create a confusing and tricky question in Java.
The answer to this question is if you put the same key again then it will replace the old mapping because HashMap doesn't allow duplicate keys. The Same key will result in the same hashcode and will end up at the same position in the bucket.
Each bucket contains a linked list of Map.Entry object, which contains both Key and Value. Now Java will take the Key object from each entry and compare it with this new key using the equals() method, if that returns true then the value object in that entry will be replaced by the new value. See How HashMap works in Java for more tricky Java questions from HashMap.
7. Question: What does the following Java program print?
public class Test { public static void main(String[] args) throws Exception { char[] chars = new char[] {'\u0097'}; String str = new String(chars); byte[] bytes = str.getBytes(); System.out.println(Arrays.toString(bytes)); } }
Answer: The trickiness of this question lies in character encoding and how String to byte array conversion works. In this program, we are first creating a String from a character array, which just has one character '\u0097', after that, we are getting the byte array from that String and print that byte.
Since \u0097 is within the 8-bit range of byte primitive type, it is reasonable to guess that the str.getBytes() call will return a byte array that contains one element with a value of -105 ((byte) 0x97).
However, that's not what the program prints and that's why this question is tricky. As a matter of fact, the output of the program is operating system and locale dependent. On a Windows XP with the US locale, the above program prints [63], if you run this program on Linux or Solaris, you will get different values.
To answer this question correctly, you need to know about how Unicode characters are represented in Java char values and in Java strings, and what role character encoding plays in String.getBytes().
In simple word, to convert a string to a byte array, Java iterates through all the characters that the string represents and turn each one into a number of bytes and finally put the bytes together. The rule that maps each Unicode character into a byte array is called a character encoding.
So It's possible that if the same character encoding is not used during both encoding and decoding then the retrieved value may not be correct. When we call str.getBytes() without specifying a character encoding scheme, the JVM uses the default character encoding of the platform to do the job.
The default encoding scheme is an operating system and locale-dependent. On Linux, it is UTF-8 and on Windows with a US locale, the default encoding is Cp1252. This explains the output we get from running this program on Windows machines with a US locale.
No matter which character encoding scheme is used, Java will always translate Unicode characters not recognized by the encoding to 63, which represents the character U+003F (the question mark, ?) in all encodings.
8. If a method throws NullPointerException in the superclass, can we override it with a method that throws RuntimeException?
One more tricky Java question from the overloading and overriding concept. The answer is you can very well throw a superclass of RuntimeException in overridden method, but you can not do the same if it's checked Exception. See Rules of method overriding in Java for more details.
9. What is the issue with the following implementation of the compareTo() method in Java where an id is an integer number?
public int compareTo(Object o){ Employee emp = (Employee) o; return this.id - e.id; }
Well, there is nothing wrong with this Java question until you guarantee that id is always positive. This Java question becomes tricky when you can't guarantee that the id is positive or negative.
The tricky part is If id becomes negative then subtraction may overflow and produce an incorrect result. See How to override the compareTo method in Java for the complete answer to this Java tricky question for an experienced programmer.
10. How do you ensure that the N thread can access N resources without deadlock? (answer)
If you are not well versed in writing multi-threading code then this is a really tricky question for you. This Java question can be tricky even for the experienced and senior programmers, who are not really exposed to deadlock and race conditions.
The key point here is ordering, if you acquire resources in a particular order and release resources in the reverse order you can prevent deadlock. If you want to prepare multithreading and concurrency in-depth, I highly recommend Java Multithreading for the Senior Engineering Interviews course on Educative.
11. Question: Consider the following Java code snippet, which is initializing two variables and both are not volatile, and two threads T1 and T2 are modifying these values as follows, both are not synchronized
int x = 0; boolean bExit = false;
Thread 1 (not synchronized) x = 1; bExit = true;
Thread 2 (not synchronized) if (bExit == true) System.out.println("x=" + x);
Now tell us, is it possible for Thread 2 to print “x=0”?
Answer: It's impossible for a list of tricky Java questions to not contain anything from multi-threading. This is the simplest one I can get. The answer to this question is Yes, It's possible that thread T2 may print x=0. Why? because without any instruction to compiler e.g. synchronized or volatile, bExit=true might come before x=1 in compiler reordering. Also, x=1 might not become visible in Thread 2, so Thread 2 will load x=0. Now, how do you fix it?
When I asked this question to a couple of programmers they answer differently, one suggests making both threads synchronized on a common mutex, another one said to make both variables volatile. Both are correct, as they will prevent reordering and guarantee visibility.
But the best answer is you just need to make bExit as volatile, then Thread 2 can only print “x=1”. x does not need to be volatile because x cannot be reordered to come after bExit=true when bExit is volatile.
12. What is the difference between CyclicBarrier and CountDownLatch in Java?
Relatively newer Java tricky question, only been introduced from Java 5. The main difference between both of them is that you can reuse CyclicBarrier even if the Barrier is broken, but you can not reuse CountDownLatch in Java. See CyclicBarrier vs CountDownLatch in Java for more differences.
13. What is the difference between StringBuffer and StringBuilder in Java?
Classic Java questions which some people think are tricky and some consider very easy. StringBuilder in Java was introduced in JDK 1.5, and the only difference between both of them is that StringBuffer methods like length(), capacity(), or append() are synchronized while corresponding methods in StringBuilder are not synchronized.
Because of this fundamental difference, concatenation of String using StringBuilder is faster than StringBuffer. Actually, it's considered a bad practice to use StringBuffer anymore, because, in almost 99% of scenarios, you perform string concatenation on the same thread. See StringBuilder vs StringBuffer for more differences.
14. Can you access a non-static variable in the static context?
Another tricky Java question from Java fundamentals. No, you can not access a non-static variable from the static context in Java. If you try, it will give a compile-time error. This is actually a common problem beginners in Java face when they try to access instance variables inside the main method.
you might be thinking "one" object but that's wrong. Btw, if you don't find these questions tricky enough, then you should check Joshua Bloch's other classic book, Java Puzzlers for super tricky questions. I am sure you will find them challenging enough.
More Trick Java Questions for Practice?
Now, it's practice time, here are some questions for you guys to answer, these are contributed by readers of this blog, big thanks to them.
- When doesn't Singleton remain Singleton in Java?
- is it possible to load a class by two ClassLoader?
- is it possible for equals() to return false, even if the contents of two Objects are the same?
- Why compareTo() should be consistent to equals() method in Java?
- When do Double and BigDecimal give different answers for equals() and compareTo() == 0.
- How does "has before" apply to volatile work?
- Why is 0.1 * 3 != 0.3,
- Why is (Integer) 1 == (Integer) 1 but (Integer) 222 != (Integer) 222 and which command arguments change this.
- What happens when an exception is thrown by a Thread?
- Difference between notify() and notifyAll() call?
- Difference between System.exit() and System.halt() method?
- Does following code legal in Java? is it an example of method overloading or overriding?
public String getDescription(Object obj){ return obj.toString; } public String getDescription(String obj){ return obj; } and public void getDescription(String obj){ return obj; }
This was my list of Some of the most common tricky questions in Java. It's not a bad idea to prepare a tricky Java question before appearing for any core Java or J2EE interview. One or two open-ended or tricky question is quite common in Java interviews.
And, If you are looking for super challenging trick coding questions then you should check out Joshua Bloch another classic book, the Java Puzzlers, I am sure you'll find them really challenging to solve, I certainly did.
Hungry for more Java Interview Question and Answer posts, check out these articles
- 18 Java design pattern questions asked in interviews
- 10 Java coding interview questions answer for 2 to 4 years experience
- Top 21 Most Frequently Asked Java Questions and Answers
- 133 Core Java Interview Questions from last 5 years
- Top 50 Multithreading and Concurrency Interview Questions
- 21 Frequently asked SQL queries from Java Interviews
- 20 Spring and REST Interview Questions
- 75 Coding Questions to Crack Any Programming Interview
- 100+ Data Structure and Algorithm Questions
- 10 Courses to learn Java for Beginners
- My Favorite books to learn Java Programming in depth
- 25 Spring Security Interview Questions for Java Programmers
- Top 20 Spring Boot Interview Questions with Answers
- 15 Java Microservice Interview Questions with Answers
- 15 Spring Data JPA Interview Questions with Answers
- 15 Spring Cloud Interview Questions with Answers
- 15 Best Java Stream and Functional Programming Questions with Answers
Thanks for reading this article so far. If you like these tricky Java interview questions or have seen them on your telephonic round of interviews, then please share this post with your friends and colleagues on Facebook, Twitter, Email, etc. If you have any questions or feedback, please drop a note.
All the best for your Job interview.