LEVEL 1:
Java Basic- Mutability, interfaces, equals, Comparable
Data Structure – Map, List, set ,tree, concrete
Exception handling
Garbage collection – locks, executor, Thread, safety
Strong Design Principles
Design Patterns
Scenario / Problem solving question (Design Pattern / Method )
LEVEL 2/3:
Design problems / Design in architectural questions
Open source – spring basic
Cache (Local / Distributor)
Transacting messaging
RDBMS
Webapp
Agile
TDD / BDD
These are the some general questions :
Core Java
1. How HashMap works internally? explain about hashCode() and
equals() methood? (Answer)
2. hashCode() method internally calls hash(int h) function. What is the use
of hash() function? What does it do?
3. What is rehashing? How HashMap does rehashing internally?
4. Write a java program to implement a custom Map implementation for
MarketPlace which internally maintais key-value pairs of stocks and its 10 last
updated values.
Why ConcurrentHashMap provides better performance than SynchronizedMap?
1. How CopyOnArrayList works?
2. What is the difference between LinkedHashSet and LinkedList?
Spring
1. Which all Spring modules have you used?
2. Explain Spring MVC life cycle.
3. Explain various bean scopes of Spring?
4. What is singleton bean scope?
5. If I am having Spring Configuration file as below :
Design Pattern
1. What is the difference between Spring Singleton Bean scope and Singleton
design pattern.
2. How you will implement Singleton Design Pattern?
3. What is double check in lazy intialization singleton pattern implementation?
SQL
1. What is index in database table? When do we need to create index on table?
2. Difference between clustered and non-clustered index
3. Design Database table design for Bank's customers and thier account.
4. When creating extra mapping table is useful.
5. Write a SQL query to find 3rd largest salary
Basic questions :
1 - sort an array containing lots of 0s, 1s and 2s
2 - Implementation of Integer.parseInt("123");
3 - Implementation of Arraylist in deep detail.
4 - Diff bw Hashmap and concurrent Hashmap and detailed implementation logic
5 - How to make a code block ThreadSafe
6 - Reenterent lock
7 - Diff bw Synchronized block and Reenterent lock
1.Creating a stack using queues.
2.What is immutability?
3.What is the hashcode and equals contract in Java
4.What if thread in a thread pool throws an Exception.
5.Difference between abstract classes and interfaces.
6.Which design patterns do you use?
More Questions
1. Explain OOPs concepts by taking example of any collection
2. How does Arraylist works internally?
3. What is the difference between LinkedList and ArrayList? When to use
LinkedList/ArrayList and Why?
4. What is Serialization and why we use?
5. In How many ways Class can be instantiated?
6. What is immutable and how we can achieve?
7. What is singleton and how we can achieve?
8. What is AtomicInteger and when to use?
9. What is CompareAndSwap/CompareAndGet?
10. How Garbage Collector works?
11. Which are syntactically correct
a. List l = new ArrayList<String>();
b. List<Object> l = new ArrayList<String>();
c. List<String> l = new ArrayList<Object>();
d. List list = new ArrayList<Object>();
list.add(“abc”);
e. List<String> l = new ArrayList();
12. What will be the output:
Class A{
public static void print(){
System.out.println(“A”);
}
}
Class B extends A{
public static void print(){
System.out.println(“B”);
}
public static void main(String[] args){
A a = new B();
a.print();
}
}
13. How does BlockingQueue work internally?
How one can implement their own lock?
multi threading and Familarity with inter-thread communication (wait, notify, join,
concurrency (hands on interrupt), executor service, callable, futures, & synchronization.
coding implemented Strong handle on multithreading. Can talk about concurrent
from scratch) collections, syncronizers (semaphores, latches, barriers).
Understanding of volatile keyword
OOPs, classes, interfaces, inner classes, Generics; Enums; access
Modifier, etc
Collections (Linked HashSet, HashMap, TreeMap etc)
pass by value/pass by reference
Multithreading (volatile, ThreadPool, Locks etc); Collection API
(Concurrent HashMap); Sync
-Can explain difference b/w various collections ArrayList,
LinkedList, HashSet. Knows about hashed & sorted collections. How
to sort objects in java.
-JMM or JVM – java memory management
XML, JMS
Data Structures Lists, Trees, Graphs, Queues, Stacks etc
Problem Solving, Time complexity analysis
Springs Should have working knowledge of Dependency Injection. Good
handle on spring core + basic understanding of AOP - Should have
worked on two or more modules of spring, e.g. AOP, MVC. Star
candidate will have the Knowledge of almost all spring modules like
web-services, remoting, used spring boot
ORM (Hibernate, JPA, Good understanding of ORM, inheritance mapping, object life-cycle,
iBatis) fetching strategies & transaction management
J unit Intermediate + knowledge of mocking frameworks. Good practices
in unit testing. How to write a highly unit-test friendly code? DI,
coding to interfaces
Design patterns Knowledge of commonly used design patterns like singleton,
factory, strategy, observer, command. Star Candidate - Have used
singleton, strategy, observer, adaptor, template, command, factory
& other patterns. Can apply appropriate DP in a given situation
Design principles and data structures in context of some real time
problem
Algorithm Solution to a simple problem - generally involves using map/list DS;
(array duplicity problem/ palindrome/ middle value of list, find
element from list etc.)
SQL Basic SQL Queries
-SQL - Understands various types of joins, group by & having clauses
DB Modeling, Query Tuning, Indexes, Query Plans etc
Store Procedures
serialization or cloning Good handle on serializable, externalizable, transient variables &
customizing serialization. Good handle on shallow & deep cloning.
Soft Skills Communication Skills, Adaptable, Never say die attitude