Java Interview Questions
Java Interview Questions
Q:
Describe synchronization in respect to multithreading.
A: With respect to multithreading, synchronization is the capability to control the
access of multiple threads to shared resources. Without synchonization, it is
possible for one thread to modify a shared variable while another thread is in the
process of using or updating same shared variable. This usually leads to
significant errors.
TOP
Q:
Explain different way of using thread?
A: The thread could be implemented by using runnable interface or by inheriting
from the Thread class. The former is more advantageous, 'cause when you are
going for multiple inheritance..the only interface can help.
TOP
Q:
What are pass by reference and passby value?
A: Pass By Reference means the passing the address itself rather than passing the
value. Passby Value means passing a copy of the value to be passed.
TOP
Q:
What is HashMap and Map?
A: Map is Interface and Hashmap is class that implements that.
TOP
Q:
Difference between HashMap and HashTable?
A: The HashMap class is roughly equivalent to Hashtable, except that it is
unsynchronized and permits nulls. (HashMap allows null values as key and value
whereas Hashtable doesnt allow). HashMap does not guarantee that the order of
the map will remain constant over time. HashMap is non synchronized and
Hashtable is synchronized.
TOP
Q:
Difference between Vector and ArrayList?
A: Vector is synchronized whereas arraylist is not.
TOP
Q:
Difference between Swing and Awt?
A: AWT are heavy-weight componenets. Swings are light-weight components. Hence
swing works faster than AWT.
TOP
Q:
What is the difference between a constructor and a method?
A: A constructor is a member function of a class that is used to create objects of that
class. It has the same name as the class itself, has no return type, and is invoked
using the new operator.
A method is an ordinary member function of a class. It has its own name, a return
type (which may be void), and is invoked using the dot operator.
TOP
Q:
What is an Iterators?
A: Some of the collection classes provide traversal of their contents via a
java.util.Iterator interface. This interface allows you to walk a collection of
objects, operating on each object in turn. Remember when using Iterators that
they contain a snapshot of the collection at the time the Iterator was obtained;
generally it is not advisable to modify the collection itself while traversing an
Iterator.
TOP
Q:
State the significance of public, private, protected, default modifiers both
singly and in combination and state the effect of package relationships on
declared items qualified by these modifiers.
A: public : Public class is visible in other packages, field is visible everywhere (class
must be public too)
private : Private variables or methods may be used only by an instance of the
same class that declares the variable or method, A private feature may only be
accessed by the class that owns the feature.
protected : Is available to all classes in the same package and also available to
all subclasses of the class that owns the protected feature.This access is provided
even to subclasses that reside in a different package from the class that owns the
protected feature.
default :What you get by default ie, without any access modifier (ie, public
private or protected).It means that it is visible to all within a particular package .
TOP
Q:
What is an abstract class?
A: Abstract class must be extended/subclassed (to be useful). It serves as a
template. A class that is abstract may not be instantiated (ie, you may not call its
constructor), abstract class may contain static data. Any class with an abstract
method is automatically abstract itself, and must be declared as such.
A class may be declared abstract even if it has no abstract methods. This prevents
it from being instantiated.
TOP
Q:
What is static in java?
A: Static means one per class, not one for each object no matter how many instance
of a class might exist. This means that you can use them without creating an
instance of a class.Static methods are implicitly final, because overriding is done
based on the type of the object, and static methods are attached to a class, not
an object. A static method in a superclass can be shadowed by another static
method in a subclass, as long as the original method was not declared final.
However, you can't override a static method with a nonstatic method. In other
words, you can't change a static method into an instance method in a subclass.
TOP
Q:
What is final?
A: A final class can't be extended ie., final class may not be subclassed. A final
method can't be overridden when its class is inherited. You can't change value of
a final variable (is a constant).
Q:
What if the main method is declared as private?
A: The program compiles properly but at runtime it will give "Main method not
public." message.
TOP
Q:
What if the static modifier is removed from the signature of the main
method?
A: Program compiles. But at runtime throws an error "NoSuchMethodError".
TOP
Q:
What if I write static public void instead of public static void?
A: Program compiles and runs properly.
TOP
Q:
What if I do not provide the String array as the argument to the method?
A: Program compiles but throws a runtime error "NoSuchMethodError".
TOP
Q:
What is the first argument of the String array in main method?
A: The String array is empty. It does not have any element. This is unlike C/C++
where the first element by default is the program name.
TOP
Q:
If I do not provide any arguments on the command line, then the String
array of Main method will be empty of null?
A: It is empty. But not null.
TOP
Q:
How can one prove that the array is not null but empty?
A: Print args.length. It will print 0. That means it is empty. But if it would have been
null then it would have thrown a NullPointerException on attempting to print
args.length.
TOP
Q:
What environment variables do I need to set on my machine in order to
be able to run Java programs?
A: CLASSPATH and PATH are the two variables.
TOP
Q:
Can an application have multiple classes having main method?
A: Yes it is possible. While starting the application we mention the class name to be
run. The JVM will look for the Main method only in the class whose name you have
mentioned. Hence there is not conflict amongst the multiple classes having main
method.
TOP
Q:
Can I have multiple main methods in the same class?
A: No the program fails to compile. The compiler says that the main method is
already defined in the class.
TOP
Q:
Do I need to import java.lang package any time? Why ?
A: No. It is by default loaded internally by the JVM.
TOP
Q:
Can I import same package/class twice? Will the JVM load the package
twice at runtime?
A: One can import the same package or same class multiple times. Neither compiler
nor JVM complains abt it. And the JVM will internally load the class only once no
matter how many times you import the same class.
TOP
Q:
What are Checked and UnChecked Exception?
A: A checked exception is some subclass of Exception (or Exception itself), excluding
class RuntimeException and its subclasses.
Making an exception checked forces client programmers to deal with the
possibility that the exception will be thrown. eg, IOException thrown by
java.io.FileInputStream's read() method·
Unchecked exceptions are RuntimeException and any of its subclasses. Class Error
and its subclasses also are unchecked. With an unchecked exception, however,
the compiler doesn't force client programmers either to catch the
exception or declare it in a throws clause. In fact, client programmers may not
even know that the exception could be thrown. eg,
StringIndexOutOfBoundsException thrown by String's charAt() method· Checked
exceptions must be caught at compile time. Runtime exceptions do not need to
be. Errors often cannot be.
TOP
Q:
What is Overriding?
A: When a class defines a method using the same name, return type, and arguments
as a method in its superclass, the method in the class overrides the method in the
superclass.
When the method is invoked for an object of the class, it is the new definition of
the method that is called, and not the method definition from superclass. Methods
may be overridden to be more public, not more private.
TOP
Q:
What are different types of inner classes?
A: Nested top-level classes, Member classes, Local classes, Anonymous classes
Nested top-level classes- If you declare a class within a class and specify the
static modifier, the compiler treats the class just like any other top-level class.
Any class outside the declaring class accesses the nested class with the declaring
class name acting similarly to a package. Eg, outer.inner. Top-level inner classes
implicitly have access only to static variables. There can also be inner interfaces.
All of these are of the nested top-level variety.
Member classes - Member inner classes are just like other member methods and
member variables and access to the member class is restricted, just like methods
and variables. This means a public member class acts similarly to a nested top-
level class. The primary difference between member classes and nested top-level
classes is that member classes have access to the specific instance of the
enclosing class.
Local classes - Local classes are like local variables, specific to a block of code.
Their visibility is only within the block of their declaration. In order for the class to
be useful beyond the declaration block, it would need to implement a
more publicly available interface.Because local classes are not members, the
modifiers public, protected, private, and static are not usable.
Anonymous classes - Anonymous inner classes extend local inner classes one
level further. As anonymous classes have no name, you cannot provide a
constructor.
Q:
Are the imports checked for validity at compile time? e.g. will the code
containing an import such as java.lang.ABCD compile?
A: Yes the imports are checked for the semantic validity at compile time. The code
containing above line of import will not compile. It will throw an error saying,can
not resolve symbol
symbol : class ABCD
location: package io
import java.io.ABCD;
TOP
Q:
Does importing a package imports the subpackages as well? e.g. Does
importing com.MyTest.* also import com.MyTest.UnitTests.*?
A: No you will have to import the subpackages explicitly. Importing com.MyTest.*
will import classes in the package MyTest only. It will not import any class in any
of it's subpackage.
TOP
Q:
What is the difference between declaring a variable and defining a
variable?
A: In declaration we just mention the type of the variable and it's name. We do not
initialize it. But defining means declaration + initialization.
e.g String s; is just a declaration while String s = new String ("abcd"); Or String s
= "abcd"; are both definitions.
TOP
Q:
What is the default value of an object reference declared as an instance
variable?
A: null unless we define it explicitly.
TOP
Q:
Can a top level class be private or protected?
A: No. A top level class can not be private or protected. It can have either "public" or
no modifier. If it does not have a modifier it is supposed to have a default
access.If a top level class is declared as private the compiler will complain that the
"modifier private is not allowed here". This means that a top level class can not be
private. Same is the case with protected.
TOP
Q:
What type of parameter passing does Java support?
A: In Java the arguments are always passed by value .
[ Update from Eki and Jyothish Venu] TOP
Q:
Primitive data types are passed by reference or pass by value?
A: Primitive data types are passed by value.
TOP
Q:
Objects are passed by value or by reference?
A: Java only supports pass by value. With objects, the object reference itself is
passed by value and so both the original reference and parameter copy both refer
to the same object .
[ Update from Eki and Jyothish Venu] TOP
Q:
What is serialization?
A: Serialization is a mechanism by which you can save the state of an object by
converting it to a byte stream.
TOP
Q:
How do I serialize an object to a file?
A: The class whose instances are to be serialized should implement an interface
Serializable. Then you pass the instance to the ObjectOutputStream which is
connected to a fileoutputstream. This will save the object to a file.
TOP
Q:
Which methods of Serializable interface should I implement?
A: The serializable interface is an empty interface, it does not contain any methods.
So we do not implement any methods.
TOP
Q:
How can I customize the seralization process? i.e. how can one have a
control over the serialization process?
A: Yes it is possible to have control over serialization process. The class should
implement Externalizable interface. This interface contains two methods namely
readExternal and writeExternal. You should implement these methods and write
the logic for customizing the serialization process.
TOP
Q:
What is the common usage of serialization?
A: Whenever an object is to be sent over the network, objects need to be serialized.
Moreover if the state of an object is to be saved, objects need to be serilazed.
TOP
Q:
What is Externalizable interface?
A: Externalizable is an interface which contains two methods readExternal and
writeExternal. These methods give you a control over the serialization mechanism.
Thus if your class implements this interface, you can customize the serialization
process by implementing these methods.
TOP
Q:
What happens to the object references included in the object?
A: The serialization mechanism generates an object graph for serialization. Thus it
determines whether the included object references are serializable or not. This is a
recursive process. Thus when an object is serialized, all the included objects are
also serialized alongwith the original obect.
TOP
Q:
What one should take care of while serializing the object?
A: One should make sure that all the included objects are also serializable. If any of
the objects is not serializable then it throws a NotSerializableException.
TOP
Q:
What happens to the static fields of a class during serialization? Are these
fields serialized as a part of each serialized object?
A: Yes the static fields do get serialized. If the static field is an object then it must
have implemented Serializable interface. The static fields are serialized as a part
of every object. But the commonness of the static fields across all the instances is
maintained even after serialization.
Q:
Does Java provide any construct to find out the size of an object?
A: No there is not sizeof operator in Java. So there is not direct way to determine the
size of an object directly in Java.
TOP
Q:
Does importing a package imports the subpackages as well? e.g. Does
importing com.MyTest.* also import com.MyTest.UnitTests.*?
A: Read the system time just before the method is invoked and immediately after
method returns. Take the time difference, which will give you the time taken by a
method for execution.
To put it in code...
Remember that if the time taken for execution is too small, it might show that it is
taking zero milliseconds for execution. Try it on a method which is big enough, in
the sense the one which is doing considerable amout of processing.
TOP
Q:
What are wrapper classes?
A: Java provides specialized classes corresponding to each of the primitive data
types. These are called wrapper classes. They are e.g. Integer, Character, Double
etc.
TOP
Q:
Why do we need wrapper classes?
A: It is sometimes easier to deal with primitives as objects. Moreover most of the
collection classes store objects and not primitive data types. And also the wrapper
classes provide many utility methods also. Because of these reasons we need
wrapper classes. And since we create instances of these classes we can store
them in any of the collection classes and pass them around as a collection. Also
we can pass them around as method parameters where a method expects an
object.
TOP
Q:
What are checked exceptions?
A: Checked exception are those which the Java compiler forces you to catch. e.g.
IOException are checked Exceptions.
TOP
Q:
What are runtime exceptions?
A: Runtime exceptions are those exceptions that are thrown at runtime because of
either wrong input data or because of wrong business logic etc. These are not
checked by the compiler at compile time.
TOP
Q:
What is the difference between error and an exception?
A: An error is an irrecoverable condition occurring at runtime. Such as OutOfMemory
error. These JVM errors and you can not repair them at runtime. While exceptions
are conditions that occur because of bad input etc. e.g. FileNotFoundException will
be thrown if the specified file does not exist. Or a NullPointerException will take
place if you try using a null reference. In most of the cases it is possible to
recover from an exception (probably by giving user a feedback for entering proper
values etc.).
TOP
Q:
How to create custom exceptions?
A: Your class should extend class Exception, or some more specific type thereof.
TOP
Q:
If I want an object of my class to be thrown as an exception object, what
should I do?
A: The class should extend from Exception class. Or you can extend your class from
some more precise exception type also.
TOP
Q:
If my class already extends from some other class what should I do if I
want an instance of my class to be thrown as an exception object?
A: One can not do anytihng in this scenarion. Because Java does not allow multiple
inheritance and does not provide any exception interface as well.
TOP
Q:
What happens to an unhandled exception?
A: One can not do anytihng in this scenarion. Because Java does not allow multiple
inheritance and does not provide any exception interface as well.
TOP
Q:
How does an exception permeate through the code?
A: An unhandled exception moves up the method stack in search of a matching
When an exception is thrown from a code which is wrapped in a try block followed
by one or more catch blocks, a search is made for matching catch block. If a
matching type is found then that block will be invoked. If a matching type is not
found then the exception moves up the method stack and reaches the caller
method. Same procedure is repeated if the caller method is included in a try catch
block. This process continues until a catch block handling the appropriate type of
exception is found. If it does not find such a block then finally the program
terminates.
TOP
Q:
What are the different ways to handle exceptions?
A: There are two ways to handle exceptions,
1. By wrapping the desired code in a try block followed by a catch block to catch
the exceptions. and
2. List the desired exceptions in the throws clause of the method and let the caller
of the method hadle those exceptions.
TOP
Q:
Q: What is the basic difference between the 2 approaches to exception
handling...1> try catch block and 2> specifying the candidate exceptions
in the throws clause?
When should you use which approach?
A: In the first approach as a programmer of the method, you urself are dealing with
the exception. This is fine if you are in a best position to decide should be done in
case of an exception. Whereas if it is not the responsibility of the method to deal
with it's own exceptions, then do not use this approach. In this case use the
second approach. In the second approach we are forcing the caller of the method
to catch the exceptions, that the method is likely to throw. This is often the
approach library creators use. They list the exception in the throws clause and we
must catch them. You will find the same approach throughout the java libraries
we use.
TOP
Q:
Is it necessary that each try block must be followed by a catch block?
A: It is not necessary that each try block must be followed by a catch block. It should
be followed by either a catch block OR a finally block. And whatever exceptions
are likely to be thrown should be declared in the throws clause of the method.
TOP
Q:
If I write return at the end of the try block, will the finally block still
execute?
A: Yes even if you write return as the last statement in the try block and no
exception occurs, the finally block will execute. The finally block will execute and
then the control return.
TOP
Q:
If I write System.exit (0); at the end of the try block, will the finally block
still execute?
A: No in this case the finally block will not execute because when you say
System.exit (0); the control immediately goes out of the program, and thus finally
never executes.
Q:
How are Observer and Observable used?
A: Objects that subclass the Observable class maintain a list of observers. When an
Observable object is updated it invokes the update() method of each of its
observers to notify the observers that it has changed state. The Observer
interface is implemented by objects that observe Observable objects.
[Received from Venkateswara Manam] TOP
Q:
What is synchronization and why is it important?
A: With respect to multithreading, synchronization is the capability to control
the access of multiple threads to shared resources. Without synchronization, it is
possible for one thread to modify a shared object while another thread is in the
process of using or updating that object's value. This often leads to
significant errors.
[ Received from Venkateswara Manam] TOP
Q:
How does Java handle integer overflows and underflows?
A: It uses those low order bytes of the result that can fit into the size of the type
allowed by the operation.
TOP
Q:
Does garbage collection guarantee that a program will not run out of
memory?
A: Garbage collection does not guarantee that a program will not run out of
memory. It is possible for programs to use up memory resources faster than they
are garbage collected. It is also possible for programs to create objects that are
not subject to garbage collection
.
TOP
Q:
What is the difference between preemptive scheduling and time slicing?
A: Under preemptive scheduling, the highest priority task executes until it enters
the waiting or dead states or a higher priority task comes into existence. Under
time slicing, a task executes for a predefined slice of time and then reenters the
pool of ready tasks. The scheduler then determines which task should execute
next, based on priority and other factors.
TOP
Q:
When a thread is created and started, what is its initial state?
A: A thread is in the ready state after it has been created and started.
[ Received from Venkateswara Manam] TOP
Q:
What is the purpose of finalization?
A: The purpose of finalization is to give an unreachable object the opportunity to
perform any cleanup processing before the object is garbage collected.
[ Received from Venkateswara Manam] TOP
Q:
What is the Locale class?
A: The Locale class is used to tailor program output to the conventions of a
particular geographic, political, or cultural region.
[ Received from Venkateswara Manam] TOP
Q:
What is the difference between a while statement and a do statement?
A: A while statement checks at the beginning of a loop to see whether the next
loop iteration should occur. A do statement checks at the end of a loop to see
whether the next iteration of a loop should occur. The do statement will
always execute the body of a loop at least once.
[ Received from Venkateswara Manam] TOP
Q:
What is the difference between static and non-static variables?
A: A static variable is associated with the class as a whole rather than with specific
instances of a class. Non-static variables take on unique values with each object
instance.
[ Received from Venkateswara Manam] TOP
Q:
How are this() and super() used with constructors?
A: Othis() is used to invoke a constructor of the same class. super() is used to
invoke a superclass constructor.
[ Received from Venkateswara Manam] TOP
Q:
What are synchronized methods and synchronized statements?
A: Synchronized methods are methods that are used to control access to an object. A
thread only executes a synchronized method after it has acquired the lock for the
method's object or class. Synchronized statements are similar to synchronized
methods. A synchronized statement can only be executed after a thread has
acquired the lock for the object or class referenced in the synchronized statement.
[ Received from Venkateswara Manam]
J2EE
JSP
Q: What is a output comment?
A: A comment that is sent to the client in the viewable page source.The JSP engine
handles an output comment as uninterpreted HTML text, returning the comment in
the HTML output sent to the client. You can see the comment by viewing the page
source from your Web browser. JSP Syntax <!-- comment [ <%= expression
%> ] --> Example 1 <!-- This is a commnet sent to client on <%= (new
java.util.Date()).toLocaleString() %> --> Displays in the page source: <!-- This
is a commnet sent to client on January 24, 2004 -->
Q: What is a Expression?
A: An expression tag contains a scripting language expression that is evaluated,
converted to a String, and inserted where the expression appears in the JSP file.
Because the value of an expression is converted to a String, you can use an
expression within text in a JSP file. Like <%= someexpression %> <%= (new
java.util.Date()).toLocaleString() %> You cannot use a semicolon to end an
expression
Q: What is a Declaration?
A: A declaration declares one or more variables or methods for use later in the JSP
source file. A declaration must contain at least one complete declarative
statement. You can declare any number of variables or methods within one
declaration tag, as long as they are separated by semicolons. The declaration
must be valid in the scripting language used in the JSP file. <%!
somedeclarations %> <%! int i = 0; %> <%! int a, b, c; %>
Q: What is a Scriptlet?
A: A scriptlet can contain any number of language statements, variable or method
declarations, or expressions that are valid in the page scripting language.Within
scriptlet tags, you can 1.Declare variables or methods to use later in the file (see
also Declaration). 2.Write expressions valid in the page scripting language (see
also Expression). 3.Use any of the JSP implicit objects or any object declared
with a <jsp:useBean> tag. You must write plain text, HTML-encoded text, or
other JSP tags outside the scriptlet. Scriptlets are executed at request time, when
the JSP engine processes the client request. If the scriptlet produces output, the
output is stored in the out object, from which you can display it.
Q: How can I implement a thread-safe JSP page? What are the advantages and
Disadvantages of using it?
A: You can make your JSPs thread-safe by having them implement the
SingleThreadModel interface. This is done by adding the directive <%@ page
isThreadSafe="false" %> within your JSP page. With this, instead of a single
instance of the servlet generated for your JSP page loaded in memory, you will
have N instances of the servlet loaded and initialized, with the service method of
each instance effectively synchronized. You can typically control the number of
instances (N) that are instantiated for all servlets implementing SingleThreadModel
through the admin screen for your JSP engine. More importantly, avoid using the
tag for variables. If you do use this tag, then you should set isThreadSafe to true,
as mentioned above. Otherwise, all requests to that page will access those
variables, causing a nasty race condition. SingleThreadModel is not recommended
for normal use. There are many pitfalls, including the example above of not being
able to use <%! %>. You should try really hard to make them thread-safe the old
fashioned way: by making them thread-safe .
Q: How can I enable session tracking for JSP pages if the browser has disabled
cookies?
A: We know that session tracking uses cookies by default to associate a session
identifier with a unique user. If the browser does not support cookies, or if
cookies are disabled, you can still enable session tracking using URL rewriting.
URL rewriting essentially includes the session ID within the link itself as a
name/value pair. However, for this to be effective, you need to append the
session ID for each and every link that is part of your servlet response.
Adding the session ID to a link is greatly simplified by means of of a couple of
methods: response.encodeURL() associates a session ID with a given URL,
and if you are using redirection, response.encodeRedirectURL() can be used
by giving the redirected URL as input. Both encodeURL() and
encodeRedirectedURL() first determine whether cookies are supported by the
browser; if so, the input URL is returned unchanged since the session ID will
be persisted as a cookie. Consider the following example, in which two JSP
files, say hello1.jsp and hello2.jsp, interact with each other. Basically, we
create a new session within hello1.jsp and place an object within this session.
The user can then traverse to hello2.jsp by clicking on the link present within
the page. Within hello2.jsp, we simply extract the object that was earlier
placed in the session and display its contents. Notice that we invoke the
encodeURL() within hello1.jsp on the link used to invoke hello2.jsp; if cookies
are disabled, the session ID is automatically appended to the URL, allowing
hello2.jsp to still retrieve the session object. Try this example first with
cookies enabled. Then disable cookie support, restart the brower, and try
again. Each time you should see the maintenance of the session across pages.
Do note that to get this example to work with cookies disabled at the browser,
your JSP engine has to support URL rewriting. hello1.jsp <%@ page
session=\"true\" %> <% Integer num = new Integer(100);
session.putValue("num",num); String url =response.encodeURL("hello2.jsp");
%> <a href=\'<%=url%>\'>hello2.jsp</a> hello2.jsp <%@ page
session="true" %> <% Integer i= (Integer )session.getValue("num");
out.println("Num value in session is " + i.intValue()); %>
Q: Explain the life cycle methods of a Servlet.
A: The javax.servlet.Servlet interface defines the three methods known as life-
cycle method. public void init(ServletConfig config) throws ServletException
public void service( ServletRequest req, ServletResponse res) throws
ServletException, IOException public void destroy() First the servlet is
constructed, then initialized wih the init() method. Any request from client are
handled initially by the service() method before delegating to the doXxx()
methods in the case of HttpServlet. The servlet is removed from service,
destroyed with the destroy() methid, then garbaged collected and finalized.
Q: What is the difference between the getRequestDispatcher(String path) method of
javax.servlet.ServletRequest interface and javax.servlet.ServletContext interface?
A: The getRequestDispatcher(String path) method of javax.servlet.ServletRequest
interface accepts parameter the path to the resource to be included or forwarded
to, which can be relative to the request of the calling servlet. If the path begins
with a "/" it is interpreted as relative to the current context root. The
getRequestDispatcher(String path) method of javax.servlet.ServletContext
interface cannot accepts relative paths. All path must sart with a "/" and are
interpreted as relative to curent context root.
Q: Explain the directory structure of a web application.
A: The directory structure of a web application consists of two parts. A private
directory called WEB-INF A public resource directory which contains public
resource folder. WEB-INF folder consists of 1. web.xml 2. classes directory 3. lib
directory
Q: What are the common mechanisms used for session tracking?
A: Cookies SSL sessions URL- rewriting
Q: Explain ServletContext.
A: ServletContext interface is a window for a servlet to view it's environment. A
servlet can use this interface to get information such as initialization parameters
for the web applicationor servlet container's version. Every web application has
one and only one ServletContext and is accessible to all active resource of that
application.
Q: What is preinitialization of a servlet?
A: A container doesnot initialize the servlets ass soon as it starts up, it initializes a
servlet when it receives a request for that servlet first time. This is called lazy
loading. The servlet specification defines the <load-on-startup> element, which
can be specified in the deployment descriptor to make the servlet container load
and initialize the servlet as soon as it starts up. The process of loading a servlet
before any request comes in is called preloading or preinitializing a servlet.
Q: What is the difference between Difference between doGet() and doPost()?
A: A doGet() method is limited with 2k of data to be sent, and doPost() method
doesn't have this limitation. A request string for doGet() looks like the following:
http://www.allapplabs.com/svt1?p1=v1&p2=v2&...&pN=vN doPost() method call
doesn't need a long text tail after a servlet name in a request. All parameters are
stored in a request itself, not in a request string, and it's impossible to guess the
data transmitted to a servlet only looking at a request string.
Q: What is the difference between HttpServlet and GenericServlet?
A: A GenericServlet has a service() method aimed to handle requests. HttpServlet
extends GenericServlet and adds support for doGet(), doPost(), doHead() methods
(HTTP 1.0) plus doPut(), doOptions(), doDelete(), doTrace() methods (HTTP 1.1).
Both these classes are abstract.
EJB
Q: What are the different kinds of enterprise beans?
A: Stateless session bean- An instance of these non-persistent EJBs provides
a service without storing an interaction or conversation state between
methods. Any instance can be used for any client. Stateful session bean-
An instance of these non-persistent EJBs maintains state across methods
and transactions. Each instance is associated with a particular client.
Entity bean- An instance of these persistent EJBs represents an object
view of the data, usually rows in a database. They have a primary key as
a unique identifier. Entity bean persistence can be either container-
managed or bean-managed. Message-driven bean- An instance of these
EJBs is integrated with the Java Message Service (JMS) to provide the
ability for message-driven beans to act as a standard JMS message
consumer and perform asynchronous processing between the server and
the JMS message producer.
Q: What is Session Bean?
A: A session bean is a non-persistent object that implements some business logic
running on the server. One way to think of a session object is as a logical
extension of the client program that runs on the server. Session beans are
used to manage the interactions of entity and other session beans,access
resources, and generally perform tasks on behalf of the client. There are two
basic kinds of session bean: stateless and stateful. Stateless session beans
are made up of business methods that behave like procedures; they operate
only on the arguments passed to them when they are invoked. Stateless beans
are called stateless because they are transient; they do not maintain business
state between method invocations.Each invocation of a stateless business
method is independent from previous invocations. Because stateless session
beans are stateless, they are easier for the EJB container to manage, so they
tend to process requests faster and use less resources. Stateful session beans
encapsulate business logic and state specific to a client. Stateful beans are
called "stateful" because they do maintain business state between method
invocations, held in memory and not persistent. Unlike stateless session beans,
clients do not share stateful beans. When a client creates a stateful bean, that
bean instance is dedicated to service only that client. This makes it possible to
maintain conversational state, which is business state that can be shared by
methods in the same stateful bean.
Q: What is Entity Bean?
A: The entity bean is used to represent data in the database. It provides an object-
oriented interface to data that would normally be accessed by the JDBC or some
other back-end API. More than that, entity beans provide a component model that
allows bean developers to focus their attention on the business logic of the bean,
while the container takes care of managing persistence,transactions, and access
control. There are two basic kinds of entity beans: container-managed ersistence
(CMP) andbean-managed persistence (BMP). Container-managed persistence
beans are the simplest for the bean developer to create and the most difficult for
the EJB server to support. This is because all the logic for synchronizing the bean's
state with the database is handled automatically by the container. This means that
the bean developer doesn't need to write any data access logic, while the EJB
server is supposed to take care of all the persistence needs automatically. With
CMP, the container manages the persistence of the entity bean. Vendor tools are
used to map the entity fields to the database and absolutely no database access
code is written in the bean class. The bean-managed persistence (BMP)
enterprise bean manages synchronizing its state with the database as directed by
the container. The bean uses a database API to read and write its fields to the
database, but the container tells it when to do each synchronization operation and
manages the transactions for the bean automatically. Bean-managed persistence
gives the bean developer the flexibility to perform persistence operations that are
too complicated for the container or to use a data source that is not supported by
the container.
Q: What are the methods of Entity Bean?
A: An entity bean consists of 4 groups of methods: 1. create methods: To create
a new instance of a CMP entity bean, and therefore insert data into the
database, the create() method on the bean's home interface must be invoked.
They look like this: EntityBeanClass ejbCreateXXX(parameters), where
EntityBeanClass is an Entity Bean you are trying to instantiate,
ejbCreateXXX(parameters) methods are used for creating Entity Bean instances
according to the parameters specified and to some programmer-defined
conditions. A bean's home interface may declare zero or more create()
methods, each of which must have corresponding ejbCreate() and
ejbPostCreate() methods in the bean class. These creation methods are linked
at run time, so that when a create() method is invoked on the home interface,
the container delegates the invocation to the corresponding ejbCreate() and
ejbPostCreate() methods on the bean class. 2. finder methods: The methods in
the home interface that begin with "find" are called the find methods. These are
used to query the EJB server for specific entity beans, based on the name of the
method and arguments passed. Unfortunately, there is no standard query
language defined for find methods, so each vendor will implement the find
method differently. In CMP entity beans, the find methods are not implemented
with matching methods in the bean class; containers implement them when the
bean is deployed in a vendor specific manner. The deployer will use vendor
specific tools to tell the container how a particular find method should behave.
Some vendors will use object-relational mapping tools to define the behavior of
a find method while others will simply require the deployer to enter the
appropriate SQL command. There are two basic kinds of find methods: single-
entity and multi-entity. Single-entity find methods return a remote reference to
the one specific entity bean that matches the find request. If no entity beans are
found, the method throws an ObjectNotFoundException . Every entity bean
must define the single-entity find method with the method name
findByPrimaryKey(), which takes the bean's primary key type as an argument.
The multi-entity find methods return a collection ( Enumeration or Collection
type) of entities that match the find request. If no entities are found, the multi-
entity find returns an empty collection. 3. remove methods: These methods
(you may have up to 2 remove methods, or don't have them at all) allow the
client to physically remove Entity beans by specifying either Handle or a Primary
Key for the Entity Bean. 4. home methods: These methods are designed and
implemented by a developer, and EJB specification doesn't have any
requirements for them except the need to throw a RemoteException is each
home method
Q: What are the methods of Entity Bean?What is the difference between Container-
Managed Persistent (CMP) bean and Bean-Managed Persistent(BMP) ?
A: Container-managed persistence beans are the simplest for the bean developer to
create and the most difficult for the EJB server to support. This is because all the
logic for synchronizing the bean's state with the database is handled automatically
by the container. This means that the bean developer doesn't need to write any
data access logic, while the EJB server is supposed to take care of all the
persistence needs automatically. With CMP, the container manages the persistence
of the entity bean. A CMP bean developer doesn't need to worry about JDBC code
and transactions, because the Container performs database calls and transaction
management instead of the programmer. Vendor tools are used to map the entity
fields to the database and absolutely no database access code is written in the
bean class. All table mapping is specified in the deployment descriptor. Otherwise,
a BMP bean developer takes the load of linking an application and a database on
his shoulders. The bean-managed persistence (BMP) enterprise bean manages
synchronizing its state with the database as directed by the container. The bean
uses a database API to read and write its fields to the database, but the container
tells it when to do each synchronization operation and manages the transactions
for the bean automatically. Bean-managed persistence gives the bean developer
the flexibility to perform persistence operations that are too complicated for the
container or to use a data source that is not supported by the container.BMP
beans are not 100% database-independent, because they may contain database-
specific code, but CMP beans are unable to perform complicated DML (data
manipulation language) statements. EJB 2.0 specification introduced some new
ways of querying database (by using the EJB QL - query language).
Q: Is it possible to share an HttpSession between a JSP and EJB? What happens when
I change a value in the HttpSession from inside an EJB?
A: You can pass the HttpSession as parameter to an EJB method, only if all objects
in session are serializable.This has to be consider as ?passed-by-value", that
means that it?s read-only in the EJB. If anything is altered from inside the EJB, it
won?t be reflected back to the HttpSession of the Servlet Container.The ?pass-by-
reference? can be used between EJBs Remote Interfaces, as they are remote
references. While it IS possible to pass an HttpSession as a parameter to an EJB
object, it is considered to be ?bad practice ? in terms of object oriented design.
This is because you are creating an unnecessary coupling between back-end
objects (ejbs) and front-end objects (HttpSession). Create a higher-level of
abstraction for your ejb?s api. Rather than passing the whole, fat, HttpSession
(which carries with it a bunch of http semantics), create a class that acts as a
value object (or structure) that holds all the data you need to pass back and forth
between front-end/back-end. Consider the case where your ejb needs to support a
non-http-based client. This higher level of abstraction will be flexible enough to
support it.
Q: The EJB container implements the EJBHome and EJBObject classes. For every
request from a unique client, does the container create a separate instance of the
generated EJBHome and EJBObject classes?
A: The EJB container maintains an instance pool. The container uses these instances
for the EJB Home reference irrespective of the client request. while refering the
EJB Object classes the container creates a separate instance for each client
request. The instance pool maintainence is up to the implementation of the
container. If the container provides one, it is available otherwise it is not
mandatory for the provider to implement it. Having said that, yes most of the
container providers implement the pooling functionality to increase the
performance of the application server. The way it is implemented is again up to
the implementer.
Q: Can the primary key in the entity bean be a Java primitive type such as int?
A: The primary key can't be a primitive type--use the primitive wrapper classes,
instead. For example, you can use java.lang.Integer as the primary key class, but
not int (it has to be a class, not a primitive)
Q: What is the advantage of using Entity bean for database operations, over directly
using JDBC API to do database operations? When would I use one over the other?
A: Entity Beans actually represents the data in a database. It is not that Entity Beans
replaces JDBC API. There are two types of Entity Beans Container Managed and
Bean Mananged. In Container Managed Entity Bean - Whenever the instance of
the bean is created the container automatically retrieves the data from the
DB/Persistance storage and assigns to the object variables in bean for user to
manipulate or use them. For this the developer needs to map the fields in the
database to the variables in deployment descriptor files (which varies for each
vendor). In the Bean Managed Entity Bean - The developer has to specifically
make connection, retrive values, assign them to the objects in the ejbLoad() which
will be called by the container when it instatiates a bean object. Similarly in the
ejbStore() the container saves the object values back the the persistance storage.
ejbLoad and ejbStore are callback methods and can be only invoked by the
container. Apart from this, when you use Entity beans you dont need to worry
about database transaction handling, database connection pooling etc. which are
taken care by the ejb container. But in case of JDBC you have to explicitly do the
above features. what suresh told is exactly perfect. ofcourse, this comes under the
database transations, but i want to add this. the great thing about the entity
beans of container managed, whenever the connection is failed during the
transaction processing, the database consistancy is mantained automatically. the
container writes the data stored at persistant storage of the entity beans to the
database again to provide the database consistancy. where as in jdbc api, we,
developers has to do manually.
Q: What is EJB QL?
A: EJB QL is a Query Language provided for navigation across a network of enterprise
beans and dependent objects defined by means of container managed persistence.
EJB QL is introduced in the EJB 2.0 specification. The EJB QL query language
defines finder methods for entity beans with container managed persistenceand is
portable across containers and persistence managers. EJB QL is used for queries
of two types of finder methods: Finder methods that are defined in the home
interface of an entity bean and which return entity objects. Select methods, which
are not exposed to the client, but which are used by the Bean Provider to select
persistent values that are maintained by the Persistence Manager or to select
entity objects that are related to the entity bean on which the query is defined.
Q: What are the special design care that must be taken when you work with local
interfaces?
A: EIt is important to understand that the calling semantics of local interfaces are
different from those of remote interfaces. For example, remote interfaces pass
parameters using call-by-value semantics, while local interfaces use call-by-
reference. This means that in order to use local interfaces safely, application
developers need to carefully consider potential deployment scenarios up front,
then decide which interfaces can be local and which remote, and finally, develop
the application code with these choices in mind. While EJB 2.0 local interfaces are
extremely useful in some situations, the long-term costs of these choices,
especially when changing requirements and component reuse are taken into
account, need to be factored into the design decision.
Q: What is the difference between Message Driven Beans and Stateless Session
beans?
A: In several ways, the dynamic creation and allocation of message-driven bean
instances mimics the behavior of stateless session EJB instances, which exist only
for the duration of a particular method call. However, message-driven beans are
different from stateless session EJBs (and other types of EJBs) in several
significant ways: Message-driven beans process multiple JMS messages
asynchronously, rather than processing a serialized sequence of method calls.
Message-driven beans have no home or remote interface, and therefore cannot be
directly accessed by internal or external clients. Clients interact with message-
driven beans only indirectly, by sending a message to a JMS Queue or Topic.
Note: Only the container directly interacts with a message-driven bean by creating
bean instances and passing JMS messages to those instances as necessary. The
Container maintains the entire lifecycle of a message-driven bean; instances
cannot be created or removed as a result of client requests or other API calls.
Struts
What is Jakarta Struts Framework? - Jakarta Struts is open source implementation of
MVC (Model-View-Controller) pattern for the development of web based applications.
Jakarta Struts is robust architecture and can be used for the development of application of
any size. Struts framework makes it much easier to design scalable, reliable Web
applications with Java.
What is ActionServlet? - The class org.apache.struts.action.ActionServlet is the called the
ActionServlet. In the the Jakarta Struts Framework this class plays the role of controller.
All the requests to the server goes through the controller. Controller is responsible for
handling all the requests.
How you will make available any Message Resources Definitions file to the Struts
Framework Environment? - Message Resources Definitions file are simple .properties
files and these files contains the messages that can be used in the struts project. Message
Resources Definitions files can be added to the struts-config.xml file through <message-
resources /> tag.
Example:
<message-resources parameter=”MessageResources” />
What is Action Class? - The Action Class is part of the Model and is a wrapper around
the business logic. The purpose of Action Class is to translate the HttpServletRequest to
the business logic. To use the Action, we need to Subclass and overwrite the execute()
method. In the Action Class all the database/business processing are done. It is advisable
to perform all the database related stuffs in the Action Class. The ActionServlet
(commad) passes the parameterized class to Action Form using the execute() method.
The return type of the execute method is ActionForward which is used by the Struts
Framework to forward the request to the file as per the value of the returned
ActionForward object.
Write code of any Action Class? - Here is the code of Action Class that returns the
ActionForward object.
import javax.servlet.http.HttpServletRequest;
import javax.servlet.http.HttpServletResponse;
import org.apache.struts.action.Action;
import org.apache.struts.action.ActionForm;
import org.apache.struts.action.ActionForward;
import org.apache.struts.action.ActionMapping;
Give the Details of XML files used in Validator Framework? - The Validator Framework
uses two XML configuration files validator-rules.xml and validation.xml. The validator-
rules.xml defines the standard validation routines, these are reusable and used in
validation.xml. to define the form specific validations. The validation.xml defines the
validations applied to a form bean.
How you will display validation fail errors on jsp page? - The following tag displays all
the errors:
<html:errors/>
How you will enable front-end validation based on the xml in validation.xml? - The
<html:javascript> tag to allow front-end validation based on the xml in validation.xml.
For example the code: <html:javascript formName=”logonForm”
dynamicJavascript=”true” staticJavascript=”true” /> generates the client side java script
for the form “logonForm” as defined in the validation.xml file. The <html:javascript>
when added in the jsp file generates the client site validation script.