Java Questions
Java Questions
Java is a collection of objects. It was developed by Sun Microsystems. There are a lot of applications,
websites, and games that are developed using Java.
OOP concepts
Object-oriented
Inheritance
Encapsulation
Polymorphism
Abstraction
Platform independent: A single program works on different platforms without any modification.
High Performance: JIT (Just In Time compiler) enables high performance in Java. JIT converts the
bytecode into machine language and then JVM starts the execution.
Multi-threaded: A flow of execution is known as a Thread. JVM creates a thread which is called the main
thread. The user can create multiple threads by extending the thread class or by implementing the
Runnable interface.
Answer: Java uses Just In Time compiler to enable high performance. It is used to convert the
instructions into bytecodes.
When a new object is created in a program a constructor gets invoked corresponding to the class.
The constructor is a method which has the same name as the class name.
If the user created a constructor with a parameter then he should create another constructor explicitly
without a parameter.
Q #6) What is meant by the Local variable and the Instance variable?
Local variables are defined in the method and scope of the variables that exist inside the method itself.
Instance variable is defined inside the class and outside the method and the scope of the variables exists
throughout the class.
Answer: All Java codes are defined in a Class. It has variables and methods.
Methods are the place where the exact business logic has to be done. It contains a set of statements (or)
instructions to satisfy the particular requirement.
Example:
public class Addition{ //Class name declaration
int b= 5;
int c = a+b;
Answer: An instance of a class is called an object. The object has state and behavior.
Whenever the JVM reads the “new()” keyword then it will create an instance of that class.
Example:
The above code creates the object for the Addition class.
Encapsulation
Polymorphism
Abstraction
Interface
Answer: Inheritance means one class can extend to another class. So that the codes can be reused from
one class to another class. The existing class is known as the Super class whereas the derived class is
known as a sub class.
Example:
Super class:
Sub class:
Inheritance is only applicable to the public and protected members only. Private members can’t be
inherited.
Code maintainability.
Example:
int a=5;
.........
For encapsulation, we need to make all the instance variables private and create setter and getter for
those variables. Which in turn will force others to call the setters rather than access the data directly.
A single object can refer to the super-class or sub-class depending on the reference type which is called
polymorphism.
Example:
Manipulation addition = new Addition();//Manipulation is reference type and Addition is reference type
addition.add();
Using the Manipulation reference type we can call the Addition class “add()” method. This ability is
known as Polymorphism. Polymorphism is applicable for overriding and not for overloading.
Answer: Method overriding happens if the sub-class method satisfies the below conditions with the
Super-class method:
The key benefit of overriding is that the Sub-class can provide some specific information about that sub-
class type than the super-class.
Example:
………………
}
Public class Addition extends Manipulation(){
………..
addition.add() method calls the add() method in the Sub-class and not the parent class. So it overrides
the Super-class method and is known as Method Overriding.
Answer: Method overloading happens for different classes or within the same class.
For method overloading, sub-class method should satisfy the below conditions with the Super-class
method (or) methods in the same class itself:
Example:
………………
………..
addition.add();
Here the add() method has different parameters in the Addition class is overloaded in the same class as
with the super-class.
Answer: Multiple inheritances cannot be achieved in java. To overcome this problem the Interface
concept is introduced.
An interface is a template which has only method declarations and not the method implementation.
Example:
All the methods in the interface are internally public abstract void.
All the variables in the interface are internally public static final that is constants.
The class which implements the interface should provide an implementation for all the methods
declared in the interface.
public class Manupulation implements IManupulation{ //Manupulation class uses the interface
……………
…………….
Answer: We can create the Abstract class by using the “Abstract” keyword before the class name. An
abstract class can have both “Abstract” methods and “Non-abstract” methods that are a concrete class.
Abstract method:
The method which has only the declaration and not the implementation is called the abstract method
and it has the keyword called “abstract”. Declarations ends with a semicolon.
Example:
The concrete Subclass which extends the Abstract class should provide the implementation for abstract
methods.
Answer: The Difference between Array and Array List can be understood from the table below:
Array
Array List
String[] name = new String[2] Size may not be required. It changes the size dynamically.
ArrayList name = new ArrayList
name.add(“book”)
Eg: This angle bracket is a type parameter which means a list of String.
Answer:
String: String variables are stored in a “constant string pool”. Once the string reference changes the old
value that exists in the “constant string pool”, it cannot be erased.
Example:
String Buffer:
Here string values are stored in a stack. If the values are changed then the new value replaces the older
value.
Example:
Stack
Once the name value has been changed to “pen” then the “book” is erased in the stack.
Stack1
String Builder:
This is the same as String Buffer except for the String Builder which is not threaded safely that is not
synchronized. So obviously the performance is fast.
Public:
Public members are visible in the same package as well as the outside package that is for other packages.
Public
Public members of Class A are visible to Class B (same package) as well as Class C (different packages).
Private:
Private members are visible in the same class only and not for the other classes in the same package as
well as classes in the outside packages.
Private
Private members in class A are visible only in that class. It is invisible for class B as well as class C.
Answer:
Default: Methods and variables declared in a class without any access specifiers are called default.
Default
Default members in Class A are visible to the other classes which are inside the package and invisible to
the classes which are outside the package.
Protected:
Protected .
Protected is the same as Default but if a class extends then it is visible even if it is outside the package.
Class A members are visible to Class B because it is inside the package. For Class C it is invisible but if
Class C extends Class A then the members are visible to Class C even if it is outside the package.
Answer: The difference between HashMap and HashTable can be seen below:
HashMap HashTable
Allows one null key and multiple null values Doesn’t allow anything that is null
Answer: The difference between HashSet and TreeSet can be seen below:
HashSet TreeSet
Inserted elements are in random order Maintains the elements in the sorted order
Answer: The differences between Abstract Class and Interface are as follows:
Abstract Class:
Abstract classes have a default constructor and it is called whenever the concrete subclass is
instantiated.
The class which extends the Abstract class shouldn’t require the implementation of all the methods, only
Abstract methods need to be implemented in the concrete sub-class.
Interface:
Classes that implement the interface should provide the implementation for all the methods.
Answer: Collection is a framework that is designed to store the objects and manipulate the design to
store the objects.
Searching
Sorting
Manipulation
Insertion
Deletion
A group of objects is known as collections. All the classes and interfaces for collecting are available in
Java util package.
Q #25) What are all the Classes and Interfaces that are available in the collections?
Answer: Given below are the Classes and Interfaces that are available in Collections:
Interfaces:
Collection
List
Set
Map
Sorted Set
Sorted Map
Queue
Classes:
Lists:
Array List
Vector
Linked List
Sets:
Hash set
Tree Set
Maps:
Hash Map
Hash Table
TreeMap
Queue:
Priority Queue
Q #26) What is meant by Ordered and Sorted in collections?
Answer:
Ordered: It means the values that are stored in a collection is based on the values that are added to the
collection. So we can iterate the values from the collection in a specific order.
Sorted: Sorting mechanisms can be applied internally or externally so that the group of objects sorted in
a particular collection is based on the properties of the objects.
Answer: Values added to the list are based on the index position and it is ordered by index position.
Duplicates are allowed.
a) Array List:
Example:
names.add (“cherry”);
names.add (“kiwi”);
names.add (“banana”);
names.add (“cherry”);
System.out.println (names);
Output:
From the output, Array List maintains the insertion order and it accepts the duplicates. But it’s not
sorted.
b) Vector:
Thread safety.
Example:
names.add (“cherry”);
names.add (“apple”);
names.add (“banana”);
names.add (“kiwi”);
names.add (“apple”);
System.out.println (“names”);
Output:
[cherry,apple,banana,kiwi,apple]
Vector also maintains the insertion order and accepts the duplicates.
c) Linked List:
In Java 5.0 it supports common queue methods peek( ), Pool ( ), Offer ( ) etc.
Example:
names.add(“banana”);
names.add(“cherry”);
names.add(“apple”);
names.add(“kiwi”);
names.add(“banana”);
System.out.println (names);
Output:
[ banana,cherry,apple,kiwi,banana]
Answer: Set cares about uniqueness. It doesn’t allow duplications. Here “equals ( )” method is used to
determine whether two objects are identical or not.
a) Hash Set:
Use this when the requirement is “no duplicates and don’t care about the order”.
Example:
names.add(“banana”);
names.add(“cherry”);
names.add(“apple”);
names.add(“kiwi”);
names.add(“banana”);
System.out.println (names);
Output:
Example:
public class Fruit {
names.add(“banana”);
names.add(“cherry”);
names.add(“apple”);
names.add(“kiwi”);
names.add(“banana”);
System.out.println (names);
Output:
It maintains the insertion order in which they have been added to the Set. Duplicates are not allowed.
c) Tree Set:
Uses the “Read-Black” tree structure and guarantees that the elements will be in ascending order.
We can construct a tree set with the constructor by using a comparable (or) comparator.
Example:
public class Fruits{
names.add(“cherry”);
names.add(“banana”);
names.add(“apple”);
names.add(“kiwi”);
names.add(“cherry”);
System.out.println(names);
Output:
TreeSet sorts the elements in ascending order. And duplicates are not allowed.
Answer: Map cares about the unique identifier. We can map a unique key to a specific value. It is a
key/value pair. We can search a value, based on the key. Like the set, the map also uses the “equals ( )”
method to determine whether two keys are the same or different.
a) Hash Map:
Unordered and unsorted map.
Example:
names.put(“key1”,“cherry”);
names.put (“key2”,“banana”);
names.put (“key3”,“apple”);
names.put (“key4”,“kiwi”);
names.put (“key1”,“cherry”);
System.out.println(names);
Output:
Example:
names.put(“key1”,“cherry”);
names.put(“key2”,“apple”);
names.put(“key3”,“banana”);
names.put(“key4”,“kiwi”);
names.put(“key2”,“orange”);
System.out.println(names);
Output:
Example:
names.put(“key1”,“cherry”);
names.put(“key2”,“apple”);
names.put(“key3”,“banana”);
names.put(“key4”,“kiwi”);
names.put(“key2”,“orange”);
System.out.println(names);
Output:
d) TreeMap:
Sorted Map.
Like Tree set, we can construct a sort order with the constructor.
Example:
names.put(“key1”,“cherry”);
names.put(“key2”,“banana”);
names.put(“key3”,“apple”);
names.put(“key4”,“kiwi”);
names.put(“key2”,“orange”);
System.out.println(names);
Output:
It is sorted in ascending order based on the key. Duplicate keys are not allowed.
Hence elements are ordered either naturally or according to the comparator. The elements ordering
represents their relative priority.
Answer: An Exception is a problem that can occur during the normal flow of execution. A method can
throw an exception when something wails at runtime. If that exception couldn’t be handled, then the
execution gets terminated before it completes the task.
If we handled the exception, then the normal flow gets continued. Exceptions are a subclass of
java.lang.Exception.
try{
}catch(Exception e){
Answer: There are two types of Exceptions. They are explained below in detail.
a) Checked Exception:
These exceptions are checked by the compiler at the time of compilation. Classes that extend Throwable
class except Runtime exception and Error are called checked Exception.
Checked Exceptions must either declare the exception using throws keyword (or) surrounded by
appropriate try/catch.
b) Unchecked Exception:
These exceptions are not checked during the compile time by the compiler. The compiler doesn’t force
to handle these exceptions. It includes:
Arithmetic Exception
ArrayIndexOutOfBounds Exception
a) Using try/catch:
The risky code is surrounded by try block. If an exception occurs, then it is caught by the catch block
which is followed by the try block.
Example:
class Manipulation{
add();
try{
addition();
}catch(Exception e){
e.printStacktrace();
At the end of the method, we can declare the exception using throws keyword.
Example:
class Manipulation{
add();
addition();
}
}
The normal flow of the execution won’t be terminated if an exception gets handled
a) try:
When a risky code is surrounded by a try block. An exception occurring in the try block is caught by a
catch block. Try can be followed either by catch (or) finally (or) both. But any one of the blocks is
mandatory.
b) catch:
c) finally:
This is followed either by try block (or) catch block. This block gets executed regardless of an exception.
So generally clean up codes are provided here.
Example:
add();
addition();
From the above example, the stack looks like as shown below:
Stack Example
If an exception occurs in the addition() method is not caught, then it moves to the method add(). Then it
is moved to the main() method and then it will stop the flow of execution. It is called Exception
Propagation.
Answer:
Final variable: Once a variable is declared as final, then the value of the variable could not be changed. It
is like a constant.
Example:
Final method: A final keyword in a method, couldn’t be overridden. If a method is marked as a final, then
it can’t be overridden by the subclass.
Final class: If a class is declared as final, then the class couldn’t be subclassed. No class can extend the
final class.
Answer: In Java, the flow of execution is called Thread. Every java program has at least one thread called
the main thread, the main thread is created by JVM. The user can define their own threads by extending
the Thread class (or) by implementing the Runnable interface. Threads are executed concurrently.
Example:
Example:
The disadvantage of using a thread class is that we cannot extend any other classes because we have
already extended the thread class. We can overload the run () method in our class.
b) Implement Runnable interface: Another way is by implementing the runnable interface. For that, we
should provide the implementation for the run () method which is defined in the interface.
Example:
Answer: Join () method is used to join one thread with the end of the currently running thread.
Example:
public static void main (String[] args){
t.start ();
t.join ();
Based on the above code, the main thread has started the execution. When it reaches the code t.start()
then ‘thread t’ starts the own stack for the execution. JVM switches between the main thread and
‘thread t’.
Once it reaches the code t.join() then ‘thread t’ alone is executed and completes its task, then only the
main thread starts the execution.
It is a non-static method. The Join () method has an overloaded version. So we can mention the time
duration in join () method also “.s”.
Q #41) What does the yield method of the Thread class do?
Answer: A yield () method moves the currently running thread to a runnable state and allows the other
threads for execution. So that equal priority threads have a chance to run. It is a static method. It doesn’t
release any lock.
Yield () method moves the thread back to the Runnable state only, and not the thread to sleep (), wait ()
(or) block.
Example:
Thread.yield();
Answer: wait () method is used to make the thread to wait in the waiting pool. When the wait () method
is executed during a thread execution then immediately the thread gives up the lock on the object and
goes to the waiting pool. Wait () method tells the thread to wait for a given amount of time.
Then the thread will wake up after notify () (or) notify all () method is called.
Wait() and the other above-mentioned methods do not give the lock on the object immediately until the
currently executing thread completes the synchronized code. It is mostly used in synchronization.
Example:
t.start ();
Synchronized (t) {
Wait();
notify() notifyAll()
This method is used to send a signal to wake up a single thread in the waiting pool. This method
sends the signal to wake up all the threads in a waiting spool.
Q #44) How to stop a thread in java? Explain about sleep () method in a thread?
Sleeping
Waiting
Blocked
Sleep: Sleep () method is used to sleep the currently executing thread for the given amount of time.
Once the thread is wake up it can move to the runnable state. So sleep () method is used to delay the
execution for some period.
It is a static method.
Example:
So it delays the thread to sleep 2 milliseconds. Sleep () method throws an uninterrupted exception,
hence we need to surround the block with try/catch.
t.start ();
try{
Thread.sleep(2000);
}catch(InterruptedException e){
Answer: If we need our class to extend some other classes other than the thread then we can go with
the runnable interface because in java we can extend only one class.
If we are not going to extend any class then we can extend the thread class.
Answer: Start() method creates a new thread and the code inside the run () method is executed in the
new thread. If we directly called the run() method then a new thread is not created and the currently
executing thread will continue to execute the run() method.
Answer: Multiple threads are executed simultaneously. Each thread starts its own stack based on the
flow (or) priority of the threads.
Example Program:
go();
On the 1st line execution, JVM calls the main method and the main thread stack looks as shown below.
Thread1
Once the execution reaches, t.start () line then a new thread is created and the new stack for the thread
is also created. Now JVM switches to the new thread and the main thread are back to the runnable
state.
Thread2
Now, the user thread executed the code inside the run() method.
Thread3
Once the run() method has completed, then JVM switches back to the main thread and the user thread
has completed the task and the stack was disappeared.
JVM switches between each thread until both the threads are completed. This is called Multi-threading.
New
Runnable
Running
Non-runnable (Blocked)
Terminated
New: In New state, a Thread instance has been created but start () method is not yet invoked. Now the
thread is not considered alive.
Runnable: The Thread is in the runnable state after the invocation of the start () method, but before the
run () method is invoked. But a thread can also return to the runnable state from waiting/sleeping. In
this state, the thread is considered alive.
Running: The thread is in a running state after it calls the run () method. Now the thread begins the
execution.
Non-Runnable(Blocked): The thread is alive but it is not eligible to run. It is not in the runnable state but
also, it will return to the runnable state after some time. Example: wait, sleep, block.
Terminated: Once the run method is completed then it is terminated. Now the thread is not alive.
Answer: Synchronization makes only one thread to access a block of code at a time. If multiple threads
accesses the block of code, then there is a chance for inaccurate results at the end. To avoid this issue,
we can provide synchronization for the sensitive block of codes.
The synchronized keyword means that a thread needs a key in order to access the synchronized code.
Locks are per objects. Every Java object has a lock. A lock has only one key. A thread can access a
synchronized method only if the thread can get the key to the objects to lock.
Example:
t.start ();
synchronized(object){
{
}
Ans: Synchronization is not recommended to implement all the methods. Because if one thread accesses
the synchronized code then the next thread should have to wait. So it makes a slow performance on the
other end.
Answer: Converting a file into a byte stream is known as Serialization. The objects in the file are
converted to bytes for security purposes. For this, we need to implement a java.io.Serializable interface.
It has no method to define.
Variables that are marked as transient will not be a part of the serialization. So we can skip the
serialization for the variables in the file by using a transient keyword.
Answer: Transient variables are not part of the serialization process. During deserialization, the values of
the transient variables are set to the default value. It is not used with static variables.
Example:
Answer: ObjectOutputStream and ObjectInputStream classes are higher level java.io. package. We will
use them with lower level classes FileOutputStream and FileInputStream.
ObjectOutputStream.writeObject —->Serialize the object and write the serialized object to a file.
Answer: Volatile variable values are always read from the main memory and not from thread’s cache
memory. This is used mainly during synchronization. It is applicable only for variables.
Example:
Answer: These are the differences between serialization and deserialization in java:
Serialization Deserialization
Serialization is the process which is used to convert the objects into byte stream Deserialization is the
opposite process of serialization where we can get the objects back from the byte stream.
Answer: Whenever an object is Serialized, the object is stamped with a version ID number for the object
class. This ID is called the SerialVersionUID. This is used during deserialization to verify that the sender
and receiver that are compatible with the Serialization.
Method References, which enable defining Lambda Expressions by referring to methods directly using
their names
Default methods, which give users the ability to add full implementations in interfaces besides abstract
methods
Nashorn, a high-performance Java-based engine integrated to JDK used to evaluate and execute
JavaScript code
Stream API, a special iterator class that allows processing object collections in a functional manner
It’s a function that can be referenced and shared as an object. Lambda Expressions require less coding,
provide a means of implementing the Java 8 functional interface, and let users encapsulate one behavior
unit to pass around to other code.
Top 25 Java 8 Interview Questions and Answers for 2022 - Basic to Experienced
By Simplilearn
Table of Contents
What is Java 8?Java 8 Interview Questions - Basic LevelJava 8 Interview Questions - Intermediate
LevelJava 8 Interview Questions - 12 years/ 10 years/ 5 years Experienced Level Do You Want a Career in
Java?
Java is a very popular programming language, found everywhere from Android apps to the Internet of
Things (IoT). In fact, Java was #1 in job postings in 2019, according to Codeplatoon. Considering its
ubiquity, it’s no surprise that there continues to be a high demand for professionals who are proficient in
Java.
That’s why we are presenting this collection of the most common Java 8-related questions and answers
found in job interviews. It’s not enough that you have extensive training and understanding in a given
subject (in this case, for instance, Java). You need to organize your thoughts, review the information on
the topic, and focus on the most likely asked questions.
We’ll begin with the basics of Java 8 and work our way up to the tougher questions. Once you get
through this material, you will be in a better position to own that critical interview!
What is Java 8?
Before we tackle the questions, let’s do a little fundamental review here, and nail down what Java 8 is.
Java 8 was released on March 14, 2014, and is described by Java as “…the latest release for Java that
contains new features, enhancements and bug fixes to improve efficiency to develop and run Java
programs.”
in Collaboration with Caltech CTMEENROLL NOWPost Graduate Program: Full Stack Web Development
Method References, which enable defining Lambda Expressions by referring to methods directly using
their names
Default methods, which give users the ability to add full implementations in interfaces besides abstract
methods
Nashorn, a high-performance Java-based engine integrated to JDK used to evaluate and execute
JavaScript code
Stream API, a special iterator class that allows processing object collections in a functional manner
Dramatic changes in hardware created the need for Java to use current multi-core CPUs more efficiently
In Partnership with HIRIST and HackerEarthEXPLORE COURSEFull Stack Java Developer Course
Lambda expressions are applied only to the functional interface’s abstract method.
8. What does the term “method reference” mean in the context of Java 8?
Method reference is a Java 8 construct used to reference a method without having to invoke it. It is a
compact method of Lambda expression.
Data types are divided into two groups: Primitive data types - includes byte , short , int , long , float ,
double , boolean and char. Non-primitive data types - such as String , Arrays and Classes