Make your own free website on Tripod.com

Core Java

THREADS

JAVA UTILS

DESIGN PATTERN

JSP

SERVLET

EJB

JNDI, JMS

RMI, JDBC, XML

 

CORE JAVA

 

Question: What is a compilation unit?  

Answer:   A compilation unit is a Java source code file. 

 

Question: What restrictions are placed on method overriding?  

Answer::   Overridden methods must have the same name, argument list, and return type.

The overriding method may not limit the access of the method it overrides.

The overriding method may not throw any exceptions that may not be thrown by the overridden method. 

 

Question: How can a dead thread be restarted?  

Answer:   A dead thread cannot be restarted. 

 

Question: What happens if an exception is not caught?  

Answer:   An uncaught exception results in the uncaughtException() method of the thread's ThreadGroup being invoked, which eventually results in the termination of the program in which it is thrown. 

 

Question: Which arithmetic operations can result in the throwing of an ArithmeticException?  

Answer:   Integer / and % can result in the throwing of an ArithmeticException 

 

Question: Can an abstract class be final?  

Answer:   An abstract class may not be declared as final 

 

Question: What happens if a try-catch-finally statement does not have a catch clause to handle an exception that is thrown within the body of the try statement?  

Answer:   The exception propagates up to the next higher level try-catch statement (if any) or results in the program's termination 

 

Question: What is numeric promotion?  

Answer:   Numeric promotion is the conversion of a smaller numeric type to a larger numeric type, so that integer and floating-point operations may take place. In numerical promotion, byte, char, and short values are converted to int values. The int values are also converted to long values, if necessary. The long and float values are converted to double values, as required 

 

Question: What is the difference between a public and a non-public class?  

Answer:   A public class may be accessed outside of its package. A non-public class may not be accessed outside of its package. 

 

Question: To what value is a variable of the boolean type automatically initialized?  

Answer:   The default value of the boolean type is false 

 

Question: Can try statements be nested?  

Answer:   Yes 

 

Question: What is the difference between the prefix and postfix forms of the ++ operator?  

Answer:   The prefix form performs the increment operation and returns the value of the increment operation. The postfix form returns the current value all of the expression and then performs the increment operation on that value. 

 

Question: What is the purpose of a statement block?  

Answer:   A statement block is used to organize a sequence of statements as a single statement group 

 

Question: What is a Java package and how is it used?  

Answer:   A Java package is a naming context for classes and interfaces. A package is used to create a separate name space for groups of classes and interfaces. Packages are also used to organize related classes and interfaces into a single API unit and to control accessibility to these classes and interfaces. 

 

Question: What modifiers may be used with a top-level class?  

Answer:   A top-level class may be public, abstract, or final. 

 

Question: What are the Object and Class classes used for?  

Answer:   The Object class is the highest-level class in the Java class hierarchy. The Class class is used to represent the classes and interfaces that are loaded by a Java program. 

 

Question: How does a try statement determine which catch clause should be used to handle an exception?  

Answer:   When an exception is thrown within the body of a try statement, the catch clauses of the try statement are examined in the order in which they appear. The first catch clause that is capable of handling the exception is executed. The remaining catch clauses are ignored. 

 

Question: What are synchronized methods and synchronized statements?  

Answer:   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. 

 

Question: What is the difference between an if statement and a switch statement?  

Answer:   The if statement is used to select among two alternatives. It uses a boolean expression to decide which alternative should be executed. The switch statement is used to select among multiple alternatives. It uses an int expression to determine which alternative should be executed. 

 

Question: What is the diffrence between inner class and nested class?  

Answer:   When a class is defined within a scope od another class, then it becomes inner class.

If the access modifier of the inner class is static, then it becomes nested class. 

 

Question: Diffrence between JRE And JVM AND JDK  

Answer:   The "JDK" is the Java Development Kit. I.e., the JDK is bundle of software that you can use to develop Java based software. The "JRE" is the Java Runtime Environment. I.e., the JRE is an implementation of the Java Virtual Machine which actually executes Java programs. Typically, each JDK contains one (or more) JRE's along with the various development tools like the Java source compilers, bundling and deployment tools, debuggers, development libraries, etc. 

 

Question: Why is not recommended to have instance variables in Interface  

Answer:   By Default, All data members and methods in an Interface are public. Having public variables in a class that will be implementing it will be violation of the Encapsulation principal. I hope that's pretty ok.. If anybody has a better framed answer. U r welcome at reema_gupta@intersolutions.stpn.soft.net 

 

Question: Can there be an abstract class with no abstract methods in it?  

Answer:   Yes 

 

Question: Can an Interface be final?  

Answer:   No 

 

Question: Can an Interface have an inner class?  

Answer:   Yes public interface abc { static int i=0; void dd(); class a1 { a1() { int j; System.out.println("in interfia"); }; public static void main(String a1[]) { System.out.println("in interfia"); } } } 

 

Question: Can we define private and protected modifiers for variables in interfaces?  

Answer:   No 

 

 

Question: What are some alternatives to inheritance?  

Answer:   Delegation is an alternative to inheritance. Delegation means that you include an instance of another class as an instance variable, and forward messages to the instance. It is often safer than inheritance because it forces you to think about each message you forward, because the instance is of a known class, rather than a new class, and because it doesn't force you to accept all the methods of the super class: you can provide only the methods that really make sense. On the other hand, it makes you write more code, and it is harder to re-use (because it is not a subclass). 

 

Question: Why isn't there operator overloading?  

Answer:   Because C++ has proven by example that operator overloading makes code almost impossible to maintain. In fact there very nearly wasn't even method overloading in Java, but it was thought that this was too useful for some very basic methods like print(). Note that some of the classes like DataOutputStream have unoverloaded methods like writeInt() and writeByte(). 

 

Question: What does it mean that a method or field is "static"?  

Answer:   Static variables and methods are instantiated only once per class. In other words they are class variables, not instance variables. If you change the value of a static variable in a particular object, the value of that variable changes for all instances of that class.

Static methods can be referenced with the name of the class rather than the name of a particular object of the class (though that works too). That's how library methods like System.out.println() work. out is a static field in the java.lang.System class. 

 

Question: How do I convert a numeric IP address like 192.18.97.39 into a hostname like java.sun.com?   (Networking)

Answer:   String hostname = InetAddress.getByName("192.18.97.39").getHostName(); 

 

Question: Diffrence between JRE And JVM AND JDK  

Answer:   Java Runtime Environment is used to excute through browser. JVM is used to execute class file.

 

Question: Why do threads block on I/O?  

Answer:   Threads block on i/o (that is enters the waiting state) so that other threads may execute while the i/o Operation is performed. 

 

Question: What is synchronization and why is it important?  

Answer:   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. 

 

Question: Is null a keyword?  

Answer:   The null value is not a keyword. 

 

Question: Which characters may be used as the second character of an identifier,but not as the first character of an identifier?  

Answer:   The digits 0 through 9 may not be used as the first character of an identifier but they may be used after the first character of an identifier. 

 

Question: What modifiers may be used with an inner class that is a member of an outer class?  

Answer:   A (non-local) inner class may be declared as public, protected, private, static, final, or abstract. 

 

Question: How many bits are used to represent Unicode, ASCII, UTF-16, and UTF-8 characters?  

Answer:   Unicode requires 16 bits and ASCII require 7 bits. Although the ASCII character set uses only 7 bits, it is usually represented as 8 bits. UTF-8 represents characters using 8, 16, and 18 bit patterns. UTF-16 uses 16-bit and larger bit patterns. 

 

Question: What are wrapped classes?  

Answer:   Wrapped classes are classes that allow primitive types to be accessed as objects. 

 

Question: What restrictions are placed on the location of a package statement within a source code file?  

Answer:   A package statement must appear as the first line in a source code file (excluding blank lines and comments). 

 

Question: What is the difference between preemptive scheduling and time slicing?  

Answer:   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. 

 

Question: What is a native method?  

Answer:   A native method is a method that is implemented in a language other than Java. 

 

Question: What are order of precedence and associativity, and how are they used?  

Answer:   Order of precedence determines the order in which operators are evaluated in expressions. Associatity determines whether an expression is evaluated left-to-right or right-to-left 

 

Question: What is the catch or declare rule for method declarations?  

Answer:   If a checked exception may be thrown within the body of a method, the method must either catch the exception or declare it in its throws clause. 

 

Question: Can an anonymous class be declared as implementing an interface and extending a class?  

Answer:   An anonymous class may implement an interface or extend a superclass, but may not be declared to do both. 

 

Question: What is the range of the char type?  

Answer:   The range of the char type is 0 to 2^16 - 1. 

 

Question: What is the purpose of finalization?  

Answer:   The purpose of finalization is to give an unreachable object the opportunity to perform any cleanup processing before the object is garbage collected. 

 

Question: What is the difference between the Boolean & operator and the && operator?  

Answer:   If an expression involving the Boolean & operator is evaluated, both operands are evaluated. Then the & operator is applied to the operand. When an expression involving the && operator is evaluated, the first operand is evaluated. If the first operand returns a value of true then the second operand is evaluated. The && operator is then applied to the first and second operands. If the first operand evaluates to false, the evaluation of the second operand is skipped. 

 

Question: How many times may an object's finalize() method be invoked by the garbage collector?  

Answer:   An object's finalize() method may only be invoked once by the garbage collector. 

 

Question: What is the purpose of the finally clause of a try-catch-finally statement?  

Answer:   The finally clause is used to provide the capability to execute code no matter whether or not an exception is thrown or caught. 

 

Question: What is the argument type of a program's main() method?  

Answer:   A program's main() method takes an argument of the String[] type. 

 

Question: Which Java operator is right associative?  

Answer:   The = operator is right associative. 

 

Question: Can a double value be cast to a byte?  

Answer:   Yes, a double value can be cast to a byte. 

 

Question: What is the difference between a break statement and a continue statement?  

Answer:   A break statement results in the termination of the statement to which it applies (switch, for, do, or while). A continue statement is used to end the current loop iteration and return control to the loop statement. 

 

Question: What must a class do to implement an interface?  

Answer:   It must provide all of the methods in the interface and identify the interface in its implements clause. 

 

Question: What is the advantage of the event-delegation model over the earlier event-inheritance model?  

Answer:   The event-delegation model has two advantages over the event-inheritance model. First, it enables event handling to be handled by objects other than the ones that generate the events (or their containers). This allows a clean separation between a component's design and its use. The other advantage of the event-delegation model is that it performs much better in applications where many events are generated. This performance improvement is due to the fact that the event-delegation model does not have to repeatedly process unhandled events, as is the case of the event-inheritance model. 

 

Question: How are commas used in the intialization and iteration parts of a for statement?  

Answer:   Commas are used to separate multiple statements within the initialization and iteration parts of a for statement. 

 

Question: What is an abstract method?  

Answer:   An abstract method is a method whose implementation is deferred to a subclass. 

 

Question: What value does read() return when it has reached the end of a file?  

Answer:   The read() method returns -1 when it has reached the end of a file. 

 

Question: Can a Byte object be cast to a double value?  

Answer:   No, an object cannot be cast to a primitive value. 

 

Question: What is the difference between a static and a non-static inner class?  

Answer:   A non-static inner class may have object instances that are associated with instances of the class's outer class. A static inner class does not have any object instances. 

 

Question: If a variable is declared as private, where may the variable be accessed?  

Answer:   A private variable may only be accessed within the class in which it is declared. 

 

Question: What is an object's lock and which object's have locks?  

Answer:   An object's lock is a mechanism that is used by multiple threads to obtain synchronized access to the object. A thread may execute a synchronized method of an object only after it has acquired the object's lock. All objects and classes have locks. A class's lock is acquired on the class's Class object. 

 

Question: What is the % operator?  

Answer:   It is referred to as the modulo or remainder operator. It returns the remainder of dividing the first operand by the second operand. 

 

Question: When can an object reference be cast to an interface reference?  

Answer:   An object reference be cast to an interface reference when the object implements the referenced interface. 

 

Question: Which class is extended by all other classes?  

Answer:   The Object class is extended by all other classes. 

 

Question: Can an object be garbage collected while it is still reachable?  

Answer:   A reachable object cannot be garbage collected. Only unreachable objects may be garbage collected. 

 

Question: Is the ternary operator written x : y ? z or x ? y : z ?  

Answer:   It is written x ? y : z. 

 

Question: How is rounding performed under integer division?  

Answer:   The fractional part of the result is truncated. This is known as rounding toward zero. 

 

Question: What is the difference between the Reader/Writer class hierarchy and the InputStream/OutputStream class hierarchy?  

Answer:   The Reader/Writer class hierarchy is character-oriented, and the InputStream/OutputStream class hierarchy is byte-oriented. 

 

Question: What classes of exceptions may be caught by a catch clause?  

Answer:   A catch clause can catch any exception that may be assigned to the Throwable type. This includes the Error and Exception types. 

 

Question: If a class is declared without any access modifiers, where may the class be accessed?  

Answer:   A class that is declared without any access modifiers is said to have package access. This means that the class can only be accessed by other classes and interfaces that are defined within the same package. 

 

Question: Does a class inherit the constructors of its superclass?  

Answer:   A class does not inherit constructors from any of its superclasses. 

 

Question: What is the purpose of the System class?  

Answer:   The purpose of the System class is to provide access to system resources. 

 

Question: Name the eight primitive Java types.  

Answer:   The eight primitive types are byte, char, short, int, long, float, double, and boolean. 

 

Question: Which class should you use to obtain design information about an object?  

Answer:   The Class class is used to obtain information about an object's design. 

 

Question: can the Kawa or any another J-editor export a .EXE file and to be has an install shield  

Answer:   I didn't know i need an answer. 

 

Question: What modifiers are allowed for methods in an Interface?  

Answer:   Only public and abstract modifiers are allowed for methods in interfaces. 

 

Question: What are the different identifier states of a Thread?  

Answer:   The different identifiers of a Thread are:

R - Running or runnable thread

S - Suspended thread

CW - Thread waiting on a condition variable

MW - Thread waiting on a monitor lock

MS - Thread suspended waiting on a monitor lock 

 

Question: What is Externalizable?  

Answer:   Externalizable is an Interface that extends Serializable Interface. And sends data into Streams in Compressed Format. It has two methods, writeExternal(ObjectOuput out) and readExternal(ObjectInput in) 

 

Question: I made my class Cloneable but I still get 'Can't access protected method clone. Why?  

Answer:   Yeah, some of the Java books, in particular "The Java Programming Language", imply that all you have to do in order to have your class support clone() is implement the Cloneable interface. Not so. Perhaps that was the intent at some point, but that's not the way it works currently. As it stands, you have to implement your own public clone() method, even if it doesn't do anything special and just calls super.clone(). 

 

Question: What is a local, member and a class variable?  

Answer:   Variables declared within a method are "local" variables.

Variables declared within the class i.e not within any methods are "member" variables (global variables).

Variables declared within the class i.e not within any methods and are defined as "static" are class variables 

 

Question: What gives java it's "write once and run anywhere" nature?  

Answer:   Java is compiled to be a byte code which is the intermediate language between source code and machine code. This byte code is not platorm specific and hence can be fed to any platform. After being fed to the JVM, which is specific to a particular operating system, the code platform specific machine code is generated thus making java platform independent. 

 

Question: What are the four corner stones of OOP ?  

Answer:   Abstraction, Encapsulation, Polymorphism and Inheritance 

 

Question: Difference between a Class and an Object ?  

Answer:   A class is a definition or prototype whereas an object is an instance or living representation of the prototype 

 

Question: What is the difference between method overriding and overloading?  

Answer:   Overriding is a method with the same name and arguments as in a parent, whereas overloading is the same method name but different arguments 

 

Question: What is a "stateless" protocol ?  

Answer:   Without getting into lengthy debates, it is generally accepted that protocols like HTTP are stateless i.e. there is no retention of state between a transaction which is a single request response combination 

 

Question: What is constructor chaining and how is it achieved in Java ?  

Answer:   A child object constructor always first needs to construct its parent (which in turn calls its parent constructor.). In Java it is done via an implicit call to the no-args constructor as the first statement. 

 

Question: What is passed by ref and what by value ?  

Answer:   All Java method arguments are passed by value. However, Java does manipulate objects by reference, and all object variables themselves are references 

Question: You can create a String object as String str = "abc"; Why cant a button object be created as Button bt = "abc";? Explain  

Answer:   The main reason you cannot create a button by Button bt1= "abc"; is because "abc" is a literal string (something slightly different than a String object, by-the-way) and bt1 is a Button object. The only object in Java that can be assigned a literal String is java.lang.String. Important to note that you are NOT calling a java.lang.String constuctor when you type String s = "abc"; 

 

Question: What does the "abstract" keyword mean in front of a method? A class?  

Answer:   Abstract keyword declares either a method or a class. If a method has a abstract keyword in front of it,it is called abstract method.Abstract method hs no body.It has only arguments and return type.Abstract methods act as placeholder methods that are implemented in the subclasses.

Abstract classes can't be instantiated.If a class is declared as abstract,no objects of that class can be created.If a class contains any abstract method it must be declared as abstract 

 

Question: How many methods do u implement if implement the Serializable Interface?  

Answer:   The Serializable interface is just a "marker" interface, with no methods of its own to implement. Other 'marker' interfaces are

java.rmi.Remote

java.util.EventListener

 

 

Question: What are the practical benefits, if any, of importing a specific class rather than an entire package (e.g. import java.net.* versus import java.net.Socket)?  

Answer:   It makes no difference in the generated class files since only the classes that are actually used are referenced by the generated class file. There is another practical benefit to importing single classes, and this arises when two (or more) packages have classes with the same name. Take java.util.Timer and javax.swing.Timer, for example. If I import java.util.* and javax.swing.* and then try to use "Timer", I get an error while compiling (the class name is ambiguous between both packages). Let's say what you really wanted was the javax.swing.Timer class, and the only classes you plan on using in java.util are Collection and HashMap. In this case, some people will prefer to import java.util.Collection and import java.util.HashMap instead of importing java.util.*. This will now allow them to use Timer, Collection, HashMap, and other javax.swing classes without using fully qualified class names in. 

 

Question: What is the difference between logical data independence and physical data independence?  

Answer:   Logical Data Independence - meaning immunity of external schemas to changeds in conceptual schema. Physical Data Independence - meaning immunity of conceptual schema to changes in the internal schema. 

 

Question: What is user defined exception ?  

Answer:   Apart from the exceptions already defined in Java package libraries, user can define his own exception classes by extending Exception class. 

 

Question: Difference Between Abstraction and Encapsulation  

Answer:   Abstraction is removing some distinctions between objects, so as to show their commonalities.

Encapsulation is hiding the details of the implementation of an object so that there are no external dependencies on the particular implementation. 

 

 

Question: Why are there no global variables in Java?  

Answer:   Global variables are considered bad form for a variety of reasons:

· Adding state variables breaks referential transparency (you no longer can understand a statement or expression on its own: you need to understand it in the context of the settings of the global variables).

· State variables lessen the cohesion of a program: you need to know more to understand how something works. A major point of Object-Oriented programming is to break up global state into more easily understood collections of local state.

· When you add one variable, you limit the use of your program to one instance. What you thought was global, someone else might think of as local: they may want to run two copies of your program at once.

For these reasons, Java decided to ban global variables. 

 

Question: What does it mean that a class or member is final?  

Answer:   A final class can no longer be subclassed. Mostly this is done for security reasons with basic classes like String and Integer. It also allows the compiler to make some optimizations, and makes thread safety a little easier to achieve.

Methods may be declared final as well. This means they may not be overridden in a subclass.

Fields can be declared final, too. However, this has a completely different meaning. A final field cannot be changed after it's initialized, and it must include an initializer statement where it's declared. For example,

public final double c = 2.998;

It's also possible to make a static field final to get the effect of C++'s const statement or some uses of C's #define, e.g.

public static final double c = 2.998;

 

 

Question: What does it mean that a method or class is abstract?  

Answer:   An abstract class cannot be instantiated. Only its subclasses can be instantiated. You indicate that a class is abstract with the abstract keyword like this:

public abstract class Container extends Component {

Abstract classes may contain abstract methods. A method declared abstract is not actually implemented in the current class. It exists only to be overridden in subclasses. It has no body. For example,

public abstract float price();

Abstract methods may only be included in abstract classes. However, an abstract class is not required to have any abstract methods, though most of them do.

Each subclass of an abstract class must override the abstract methods of its superclasses or itself be declared abstract.

 

Question: what is a transient variable?  

Answer:   transient variable is a variable that may not be serialized. 

 

Question: How are Observer and Observable used?  

Answer:   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. 

 

Question: Can a lock be acquired on a class?  

Answer:   Yes, a lock can be acquired on a class. This lock is acquired on the class's Class object. 

 

Question: What state does a thread enter when it terminates its processing?  

Answer:   When a thread terminates its processing, it enters the dead state. 

 

Question: How does Java handle integer overflows and underflows?  

Answer:   It uses those low order bytes of the result that can fit into the size of the type allowed by the operation. 

 

Question: What is the difference between the >> and >>> operators?  

Answer:   The >> operator carries the sign bit when shifting right. The >>> zero-fills bits that have been shifted out. 

 

Question: Is sizeof a keyword?  

Answer:   The sizeof operator is not a keyword. 

 

Question: Does garbage collection guarantee that a program will not run out of memory?  

Answer:   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 

 

Question: Can an object's finalize() method be invoked while it is reachable?  

Answer:   An object's finalize() method cannot be invoked by the garbage collector while the object is still reachable. However, an object's finalize() method may be invoked by other objects. 

 

Question: What value does readLine() return when it has reached the end of a file?  

Answer:   The readLine() method returns null when it has reached the end of a file. 

 

Question: Can a for statement loop indefinitely?  

Answer:   Yes, a for statement can loop indefinitely. For example, consider the following: for(;;) ; 

 

Question: To what value is a variable of the String type automatically initialized?  

Answer:   The default value of an String type is null. 

 

Question: What is a task's priority and how is it used in scheduling?  

Answer:   A task's priority is an integer value that identifies the relative order in which it should be executed with respect to other tasks. The scheduler attempts to schedule higher priority tasks before lower priority tasks. 

 

Question: What is the range of the short type?  

Answer:   The range of the short type is -(2^15) to 2^15 - 1. 

 

Question: What is the purpose of garbage collection?  

Answer:   The purpose of garbage collection is to identify and discard objects that are no longer needed by a program so that their resources may be reclaimed and reused. 

 

Question: How may messaging models do JMS provide for and what are they?  

Answer:   JMS provide for two messaging models, publish-and-subscribe and point-to-point queuing 

 

Question: What information is needed to create a TCP Socket?   (Networking)

Answer:   The Local System?s IP Address and Port Number. And the Remote System's IPAddress and Port Number. 

 

Question: What Class.forName will do while loading drivers?   (JDBC)

Answer:   It is used to create an instance of a driver and register it with the DriverManager. When you have loaded a driver, it is available for making a connection with a DBMS. 

 

Question: How to Retrieve Warnings?   (JDBC)

Answer:   SQLWarning objects are a subclass of SQLException that deal with database access warnings. Warnings do not stop the execution of an application, as exceptions do; they simply alert the user that something did not happen as planned. A warning can be reported on a Connection object, a Statement object (including PreparedStatement and CallableStatement objects), or a ResultSet object. Each of these classes has a getWarnings method, which you must invoke in order to see the first warning reported on the calling object

E.g.

SQLWarning warning = stmt.getWarnings();

if (warning != null) {

while (warning != null) {

System.out.println("Message: " + warning.getMessage());

System.out.println("SQLState: " + warning.getSQLState());

System.out.print("Vendor error code: ");

System.out.println(warning.getErrorCode());

warning = warning.getNextWarning();

}

 

Question: How many JSP scripting elements are there and what are they?   (JSP)

Answer:   There are three scripting language elements:

declarations

scriptlets

expressions

 

Question: In the Servlet 2.4 specification SingleThreadModel has been deprecates, why?   (JSP)

Answer:   Because it is not practical to have such model. Whether you set isThreadSafe to true or false, you should take care of concurrent client requests to the JSP page by synchronizing access to any shared objects defined at the page level. 

 

Question: what are stored procedures? How is it useful?   (JDBC)

Answer:   A stored procedure is a set of statements/commands which reside in the database. The stored procedure is precompiled and saves the database the effort of parsing and compiling sql statements everytime a query is run. Each Database has it's own stored procedure language, usually a variant of C with a SQL preproceesor. Newer versions of db's support writing stored procs in Java and Perl too.

Before the advent of 3-tier/n-tier architecture it was pretty common for stored procs to implement the business logic( A lot of systems still do it). The biggest advantage is of course speed. Also certain kind of data manipulations are not achieved in SQL. Stored procs provide a mechanism to do these manipulations. Stored procs are also useful when you want to do Batch updates/exports/houseKeeping kind of stuff on the db. The overhead of a JDBC Connection may be significant in these cases. 

 

Question: What do you understand by private, protected and public?  

Answer:   These are accessibility modifiers. Private is the most restrictive, while public is the least restrictive. There is no real difference between protected and the default type (also known as package protected) within the context of the same package, however the protected keyword allows visibility to a derived class in a different package. 

 

Question: What is Downcasting ?  

Answer:   Downcasting is the casting from a general to a more specific type, i.e. casting down the hierarchy 

 

Question: Can a method be overloaded based on different return type but same argument type ?  

Answer:   No, because the methods can be called without using their return type in which case there is ambiquity for the compiler 

 

Question: What happens to a static var that is defined within a method of a class ?  

Answer:   Can't do it. You'll get a compilation error 

 

Question: How many static init can you have ?  

Answer:   As many as you want, but the static initializers and class variable initializers are executed in textual order and may not refer to class variables declared in the class whose declarations appear textually after the use, even though these class variables are in scope. 

 

Question: What is the difference amongst JVM Spec, JVM Implementation, JVM Runtime ?  

Answer:   The JVM spec is the blueprint for the JVM generated and owned by Sun. The JVM implementation is the actual implementation of the spec by a vendor and the JVM runtime is the actual running instance of a JVM implementation 

 

Question: Describe what happens when an object is created in Java?  

Answer:   Several things happen in a particular order to ensure the object is constructed properly:

1. Memory is allocated from heap to hold all instance variables and implementation-specific data of the object and its superclasses. Implemenation-specific data includes pointers to class and method data.

2. The instance variables of the objects are initialized to their default values.

3. The constructor for the most derived class is invoked. The first thing a constructor does is call the consctructor for its superclasses. This process continues until the constrcutor for java.lang.Object is called, as java.lang.Object is the base class for all objects in java.

4. Before the body of the constructor is executed, all instance variable initializers and initialization blocks are executed. Then the body of the constructor is executed. Thus, the constructor for the base class completes first and constructor for the most derived class completes last. 

 

Question: What does the "final" keyword mean in front of a variable? A method? A class?  

Answer:   FINAL for a variable : value is constant

FINAL for a method : cannot be overridden

FINAL for a class : cannot be derived 

 

Question: What is the difference between instanceof and isInstance?  

Answer:   instanceof is used to check to see if an object can be cast into a specified type without throwing a cast class exception.

isInstance()

Determines if the specified Object is assignment-compatible with the object represented by this Class. This method is the dynamic equivalent of the Java language instanceof operator. The method returns true if the specified Object argument is non-null and can be cast to the reference type represented by this Class object without raising a ClassCastException. It returns false otherwise. 

 

Question: Wha is the output from System.out.println("Hello"+null);  

Answer:   Hellonull 

 

Question: Whats the difference between notify() and notifyAll()?  

Answer:   notify() is used to unblock one waiting thread; notifyAll() is used to unblock all of them. Using notify() is preferable (for efficiency) when only one blocked thread can benefit from the change (for example, when freeing a buffer back into a pool). notifyAll() is necessary (for correctness) if multiple threads should resume (for example, when releasing a "writer" lock on a file might permit all "readers" to resume). 

 

Question: Why can't I say just abs() or sin() instead of Math.abs() and Math.sin()?  

Answer:   The import statement does not bring methods into your local name space. It lets you abbreviate class names, but not get rid of them altogether. That's just the way it works, you'll get used to it. It's really a lot safer this way. <br> However, there is actually a little trick you can use in some cases that gets you what you want. If your top-level class doesn't need to inherit from anything else, make it inherit from java.lang.Math. That *does* bring all the methods into your local name space. But you can't use this trick in an applet, because you have to inherit from java.awt.Applet. And actually, you can't use it on java.lang.Math at all, because Math is a "final" class which means it can't be extended. 

Question: Is "abc" a primitive value?  

Answer:   The String literal "abc" is not a primitive value. It is a String object. 

 

Question: What restrictions are placed on the values of each case of a switch statement?  

Answer:   During compilation, the values of each case of a switch statement must evaluate to a value that can be promoted to an int value. 

 

Question: What modifiers may be used with an interface declaration?  

Answer:   An interface may be declared as public or abstract. 

 

Question: Is a class a subclass of itself?  

Answer:   A class is a subclass of itself. 

 

Question: What is the difference between a while statement and a do statement?  

Answer:   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. 

 

Question: What modifiers can be used with a local inner class?  

Answer:   A local inner class may be final or abstract. 

 

Question: What is the purpose of the File class?  

Answer:   The File class is used to create objects that provide access to the files and directories of a local file system. 

 

Question: Can an exception be rethrown?  

Answer:   Yes, an exception can be rethrown. 

 

Question: When does the compiler supply a default constructor for a class?  

Answer:   The compiler supplies a default constructor for a class if no other constructors are provided. 

 

Question: If a method is declared as protected, where may the method be accessed?  

Answer:   A protected method may only be accessed by classes or interfaces of the same package or by subclasses of the class in which it is declared. 

 

Question: Which non-Unicode letter characters may be used as the first character of an identifier?  

Answer:   The non-Unicode letter characters $ and _ may appear as the first character of an identifier 

 

Question: What restrictions are placed on method overloading?  

Answer:   Two methods may not have the same name and argument list but different return types. 

 

Question: What is casting?  

Answer:   There are two types of casting, casting between primitive numeric types and casting between object references. Casting between numeric types is used to convert larger values, such as double values, to smaller values, such as byte values. Casting between object references is used to refer to an object by a compatible class, interface, or array type reference. 

 

Question: What is the return type of a program's main() method?  

Answer:   A program's main() method has a void return type. 

 

Question: What class of exceptions are generated by the Java run-time system?  

Answer:   The Java runtime system generates RuntimeException and Error exceptions. 

 

Question: What class allows you to read objects directly from a stream?  

Answer:   The ObjectInputStream class supports the reading of objects from input streams. 

 

Question: What is the difference between a field variable and a local variable?  

Answer:   A field variable is a variable that is declared as a member of a class. A local variable is a variable that is declared local to a method. 

 

Question: How are this() and super() used with constructors?  

Answer:   this() is used to invoke a constructor of the same class. super() is used to invoke a superclass constructor. 

 

Question: What is the relationship between a method's throws clause and the exceptions that can be thrown during the method's execution?  

Answer:   A method's throws clause must declare any checked exceptions that are not caught within the body of the method. 

 

Question: Why are the methods of the Math class static?  

Answer:   So they can be invoked as if they are a mathematical code library. 

 

Question: What are the legal operands of the instanceof operator?  

Answer:   The left operand is an object reference or null value and the right operand is a class, interface, or array type. 

 

Question: What an I/O filter?  

Answer:   An I/O filter is an object that reads from one stream and writes to another, usually altering the data in some way as it is passed from one stream to another. 

 

Question: If an object is garbage collected, can it become reachable again?  

Answer:   Once an object is garbage collected, it ceases to exist. It can no longer become reachable again. 

 

Question: What are E and PI?  

Answer:   E is the base of the natural logarithm and PI is mathematical value pi. 

 

Question: Are true and false keywords?  

Answer:   The values true and false are not keywords. 

 

Question: What is the difference between the File and RandomAccessFile classes?  

Answer:   The File class encapsulates the files and directories of the local file system. The RandomAccessFile class provides the methods needed to directly access data contained in any part of a file. 

 

Question: What happens when you add a double value to a String?  

Answer:   The result is a String object. 

 

Question: What is your platform's default character encoding?  

Answer:   If you are running Java on English Windows platforms, it is probably Cp1252. If you are running Java on English Solaris platforms, it is most likely 8859_1. 

 

Question: Which package is always imported by default?  

Answer:   The java.lang package is always imported by default. 

 

Question: What interface must an object implement before it can be written to a stream as an object?  

Answer:   An object must implement the Serializable or Externalizable interface before it can be written to a stream as an object. 

 

Top


 

 

THREADS

 

Question: What is the difference between yielding and sleeping?  

Answer:   When a task invokes its yield() method, it returns to the ready state. When a task invokes its sleep() method, it returns to the waiting state. 

 

Question: When a thread blocks on I/O, what state does it enter?  

Answer:   A thread enters the waiting state when it blocks on I/O. 

 

Question: When a thread is created and started, what is its initial state?  

Answer:   A thread is in the ready state after it has been created and started. 

 

Question: What invokes a thread's run() method?  

Answer:   After a thread is started, via its start() method or that of the Thread class, the JVM invokes the thread's run() method when the thread is initially executed. 

 

Question: What method is invoked to cause an object to begin executing as a separate thread?  

Answer:   The start() method of the Thread class is invoked to cause an object to begin executing as a separate thread. 

 

Question: What is the purpose of the wait(), notify(), and notifyAll() methods?  

Answer:   The wait(),notify(), and notifyAll() methods are used to provide an efficient way for threads to wait for a shared resource. When a thread executes an object's wait() method, it enters the waiting state. It only enters the ready state after another thread invokes the object's notify() or notifyAll() methods. 

 

Question: What are the high-level thread states?  

Answer:   The high-level thread states are ready, running, waiting, and dead 

 

Question: What happens when a thread cannot acquire a lock on an object?  

Answer:   If a thread attempts to execute a synchronized method or synchronized statement and is unable to acquire an object's lock, it enters the waiting state until the lock becomes available. 

 

Question: How does multithreading take place on a computer with a single CPU?  

Answer:   The operating system's task scheduler allocates execution time to multiple tasks. By quickly switching between executing tasks, it creates the impression that tasks execute sequentially. 

 

Question: What happens when you invoke a thread's interrupt method while it is sleeping or waiting?  

Answer:   When a task's interrupt() method is executed, the task enters the ready state. The next time the task enters the running state, an InterruptedException is thrown. 

 

Question: What state is a thread in when it is executing?  

Answer:   An executing thread is in the running state 

 

Question: What are three ways in which a thread can enter the waiting state?  

Answer:   A thread can enter the waiting state by invoking its sleep() method, by blocking on I/O, by unsuccessfully attempting to acquire an object's lock, or by invoking an object's wait() method. It can also enter the waiting state by invoking its (deprecated) suspend() method. 

 

Question: What method must be implemented by all threads?  

Answer:   All tasks must implement the run() method, whether they are a subclass of Thread or implement the Runnable interface. 

 

Question: What are the two basic ways in which classes that can be run as threads may be defined?  

Answer:   A thread class may be declared as a subclass of Thread, or it may implement the Runnable interface. 

 

Top


 

JAVA UTILS

 

Question: What is the Collections API?  

Answer:   The Collections API is a set of classes and interfaces that support operations on collections of objects 

 

Question: What is the List interface?  

Answer:   The List interface provides support for ordered collections of objects. 

 

Question: What is the Vector class?  

Answer:   The Vector class provides the capability to implement a growable array of objects 

 

Question: What is an Iterator interface?  

Answer:   The Iterator interface is used to step through the elements of a Collection 

 

Question: Which java.util classes and interfaces support event handling?  

Answer:   The EventObject class and the EventListener interface support event processing 

 

Question: What is the GregorianCalendar class?  

Answer:   The GregorianCalendar provides support for traditional Western calendars 

 

Question: What is the Locale class?  

Answer:   The Locale class is used to tailor program output to the conventions of a particular geographic, political, or cultural region 

 

Question: What is the SimpleTimeZone class?  

Answer:   The SimpleTimeZone class provides support for a Gregorian calendar 

 

Question: What is the Map interface?  

Answer:   The Map interface replaces the JDK 1.1 Dictionary class and is used associate keys with values 

 

Question: What is the highest-level event class of the event-delegation model?  

Answer:   The java.util.EventObject class is the highest-level class in the event-delegation class hierarchy 

 

Question: What is the Collection interface?  

Answer:   The Collection interface provides support for the implementation of a mathematical bag - an unordered collection of objects that may contain duplicates 

 

Question: What is the Set interface?  

Answer:   The Set interface provides methods for accessing the elements of a finite mathematical set. Sets do not allow duplicate elements 

 

Question: What is the purpose of the enableEvents() method?  

Answer:   The enableEvents() method is used to enable an event for a particular object. Normally, an event is enabled when a listener is added to an object for a particular event. The enableEvents() method is used by objects that handle events by overriding their event-dispatch methods. 

 

Question: What is the ResourceBundle class?  

Answer:   The ResourceBundle class is used to store locale-specific resources that can be loaded by a program to tailor the program's appearance to the particular locale in which it is being run. 

 

Top


 

 

DESIGN PATTERN

 

Question: Describe the visitor design pattern  

Answer:   Represents an operation to be performed on the elements of an object structure. Visitor lets you define a new operation without changing the classes of the elements on which it operates. The root of a class hierarchy defines an abstract method to accept a visitor. Subclasses implement this method with visitor.visit(this). The Visitor interface has visit methods for all subclasses of the baseclass in the hierarchy. 

 

Question: What is a design pattern?  

Answer:   A design pattern systematically names, motivates, and explains a general design that addresses a recurring design problem. 

 

Question: Describe the visitor design pattern  

Answer:   Represents an operation to be performed on the elements of an object structure. Visitor lets you define a new operation without changing the classes of the elements on which it operates.

The root of a class hierarchy defines an abstract method to accept a visitor. Subclasses implement this method with visitor.visit(this). The Visitor interface has visit methods for all subclasses of the baseclass in the hierarchy. 

 

Top


 

 

JSP

Question:   How do I mix JSP and SSI #include?  

Answer:   If you're just including raw HTML, use the #include directive as usual inside your .jsp file.

<!--#include file="data.inc"-->

But it's a little trickier if you want the server to evaluate any JSP code that's inside the included file. If your data.inc file contains jsp code you will have to use

<%@ vinclude="data.inc" %>

The <!--#include file="data.inc"--> is used for including non-JSP files. 

 

Question:   Can a JSP page process HTML FORM data?  

Answer:   Yes. However, unlike servlets, you are not required to implement HTTP-protocol specific methods like doGet() or doPost() within your JSP page. You can obtain the data for the FORM input elements via the request implicit object within a scriptlet or expression as:

<%

String item = request.getParameter("item");

int howMany = new Integer(request.getParameter("units")).intValue();

%>

or

<%= request.getParameter("item") %>

 

 

Question:   What JSP lifecycle methods can I override?  

Answer:   You cannot override the _jspService() method within a JSP page. You can however, override the jspInit() and jspDestroy() methods within a JSP page. jspInit() can be useful for allocating resources like database connections, network connections, and so forth for the JSP page. It is good programming practice to free any allocated resources within jspDestroy().

The jspInit() and jspDestroy() methods are each executed just once during the lifecycle of a JSP page and are typically declared as JSP declarations:

<%!

public void jspInit() {

. . .

}

%>

 

<%!

public void jspDestroy() {

. . .

}

%>

 

 

Question:   How do I include static files within a JSP page?  

Answer:   Static resources should always be included using the JSP include directive. This way, the inclusion is performed just once during the translation phase. The following example shows the syntax:

<%@ include file="copyright.html" %>

Do note that you should always supply a relative URL for the file attribute. Although you can also include static resources using the action, this is not advisable as the inclusion is then performed for each and every request. 

 

Question:   How do I perform browser redirection from a JSP page?  

Answer:   You can use the response implicit object to redirect the browser to a different resource, as:

response.sendRedirect("http://www.foo.com/path/error.html");

You can also physically alter the Location HTTP header attribute, as shown below:

<%

response.setStatus(HttpServletResponse.SC_MOVED_PERMANENTLY);

String newLocn = "/newpath/index.html";

response.setHeader("Location",newLocn);

%>

You can also use the: <jsp:forward page="/newpage.jsp" /> Also note that you can only use this before any output has been sent to the client. I beleve this is the case with the response.sendRedirect() method as well.

If you want to pass any paramateres then you can pass using <jsp:forward page="/servlet/login"> <jsp:param name="username" value="jsmith" /> </jsp:forward>> 

 

Question:   Can a JSP page instantiate a serialized bean?  

Answer:   No problem! The useBean action specifies the beanName attribute, which can be used for indicating a serialized bean. For example:

<jsp:useBean id="shop" type="shopping.CD" beanName="CD" /> <jsp:getProperty name="shop" property="album" />

A couple of important points to note. Although you would have to name your serialized file "filename.ser", you only indicate "filename" as the value for the beanName attribute. Also, you will have to place your serialized file within the WEB-INF\jsp\beans directory for it to be located by the JSP engine. 

 

Question:   Can you make use of a ServletOutputStream object from within a JSP page?  

Answer:   No. You are supposed to make use of only a JSPWriter object (given to you in the form of the implicit object out) for replying to clients. A JSPWriter can be viewed as a buffered version of the stream object returned by response.getWriter(), although from an implementational perspective, it is not. A page author can always disable the default buffering for any page using a page directive as:

<%@ page buffer="none" %> 

 

Question:   What's a better approach for enabling thread-safe servlets and JSPs? SingleThreadModel Interface or Synchronization?  

Answer:   Although the SingleThreadModel technique is easy to use, and works well for low volume sites, it does not scale well. If you anticipate your users to increase in the future, you may be better off implementing explicit synchronization for your shared data. The key however, is to effectively minimize the amount of code that is synchronzied so that you take maximum advantage of multithreading.

Also, note that SingleThreadModel is pretty resource intensive from the server's perspective. The most serious issue however is when the number of concurrent requests exhaust the servlet instance pool. In that case, all the unserviced requests are queued until something becomes free - which results in poor performance. Since the usage is non-deterministic, it may not help much even if you did add more memory and increased the size of the instance pool. 

 

Question:   Can I stop JSP execution while in the midst of processing a request?  

Answer:   Yes. Preemptive termination of request processing on an error condition is a good way to maximize the throughput of a high-volume JSP engine. The trick (asuming Java is your scripting language) is to use the return statement when you want to terminate further processing. For example, consider:

<% if (request.getParameter("foo") != null) {

// generate some html or update bean property

} else {

/* output some error message or provide redirection back to the input form after creating a memento bean updated with the 'valid' form elements that were input. this bean can now be used by the previous form to initialize the input elements that were valid then, return from the body of the _jspService() method to terminate further processing */

return;

}

%> 

 

Question:   How can I get to view any compilation/parsing errors at the client while developing JSP pages?  

Answer:   With JSWDK 1.0, set the following servlet initialization property within the \WEB-INF\servlets.properties file for your application:

jsp.initparams=sendErrToClient=true

This will cause any compilation/parsing errors to be sent as part of the response to the client. 

 

Question:   Is there a way to reference the "this" variable within a JSP page?  

Answer:   Yes, there is. Under JSP 1.0, the page implicit object is equivalent to "this", and returns a reference to the servlet generated by the JSP page. 

 

Question:   How do I instantiate a bean whose constructor accepts parameters using the useBean tag?  

Answer:   Consider the following bean: package bar;

public class FooBean {

public FooBean(SomeObj arg) {

...

}

//getters and setters here

}

The only way you can instantiate this bean within your JSP page is to use a scriptlet. For example, the following snippet creates the bean with session scope:

&l;% SomeObj x = new SomeObj(...);

bar.FooBean foobar = new FooBean(x);

session.putValue("foobar",foobar);

%> You can now access this bean within any other page that is part of the same session as: &l;%

bar.FooBean foobar = session.getValue("foobar");

%>

To give the bean "application scope", you will have to place it within the ServletContext as:

&l;%

application.setAttribute("foobar",foobar);

%>

To give the bean "request scope", you will have to place it within the request object as:

&l;%

request.setAttribute("foobar",foobar);

%>

If you do not place the bean within the request, session or application scope, the bean can be accessed only within the current JSP page (page scope).

Once the bean is instantiated, it can be accessed in the usual way:

jsp:getProperty name="foobar" property="someProperty"/ jsp:setProperty name="foobar" property="someProperty" value="someValue"/ 

 

Question:   Can I invoke a JSP error page from a servlet?  

Answer:   Yes, you can invoke the JSP error page and pass the exception object to it from within a servlet. The trick is to create a request dispatcher for the JSP error page, and pass the exception object as a javax.servlet.jsp.jspException request attribute. However, note that you can do this from only within controller servlets. If your servlet opens an OutputStream or PrintWriter, the JSP engine will throw the following translation error:

java.lang.IllegalStateException: Cannot forward as OutputStream or Writer has already been obtained

The following code snippet demonstrates the invocation of a JSP error page from within a controller servlet:

protected void sendErrorRedirect(HttpServletRequest request, HttpServletResponse response, String errorPageURL, Throwable e) throws ServletException, IOException {

request.setAttribute ("javax.servlet.jsp.jspException", e);

getServletConfig().getServletContext(). getRequestDispatcher(errorPageURL).forward(request, response);

}

public void doPost(HttpServletRequest request, HttpServletResponse response) {

try {

// do something

} catch (Exception ex) {

try {

sendErrorRedirect(request,response,"/jsp/MyErrorPage.jsp",ex);

} catch (Exception e) {

e.printStackTrace();

}

}

 

Question: Can we implement an interface in a JSP?  

Answer:   No 

 

Question: What is the difference between ServletContext and PageContext?  

Answer:   ServletContext: Gives the information about the container

PageContext: Gives the information about the Request 

 

Question: What is the difference in using request.getRequestDispatcher() and context.getRequestDispatcher()?  

Answer:   request.getRequestDispatcher(path): In order to create it we need to give the relative path of the resource

context.getRequestDispatcher(path): In order to create it we need to give the absolute path of the resource. 

 

Question: How to pass information from JSP to included JSP?  

Answer:   Using <%jsp:param> tag. 

 

Question: What is the difference between directive include and jsp include?  

Answer:   <%@ include> : Used to include static resources during translation time.

: Used to include dynamic content or static content during runtime. 

 

Question: What is the difference between RequestDispatcher and sendRedirect?  

Answer:   RequestDispatcher: server-side redirect with request and response objects.

sendRedirect : Client-side redirect with new request and response objects. 

 

Question: How does JSP handle runtime exceptions?  

Answer:   Using errorPage attribute of page directive and also we need to specify isErrorPage=true if the current page is intended to URL redirecting of a JSP. 

 

Question: How do you delete a Cookie within a JSP?  

Answer:  

 Cookie mycook = new Cookie("name","value"); response.addCookie(mycook); Cookie killmycook = new Cookie("mycook","value"); killmycook.setMaxAge(0);

killmycook.setPath("/"); killmycook.addCookie(killmycook);

 

Question: How do I mix JSP and SSI #include?  

Answer:   If you're just including raw HTML, use the #include directive as usual inside your .jsp file.

<!--#include file="data.inc"-->

But it's a little trickier if you want the server to evaluate any JSP code that's inside the included file. Ronel Sumibcay (ronel@LIVESOFTWARE.COM) says: If your data.inc file contains jsp code you will have to use

<%@ vinclude="data.inc" %>

The <!--#include file="data.inc"--> is used for including non-JSP files. 

 

Question: How can you store international / Unicode characters into a cookie?  

Answer:   One way is, before storing the cookie URLEncode it.

URLEnocder.encoder(str);

And use URLDecoder.decode(str) when you get the stored cookie.

Question: What are the implicit objects?  

Answer:   Implicit objects are objects that are created by the web container and contain information related to a particular request, page, or application. They are:

request

response

pageContext

session

application

out

config

page

exception

 

 

Question: Is JSP technology extensible?  

Answer:   YES. JSP technology is extensible through the development of custom actions, or tags, which are encapsulated in tag libraries 

 

 

Question: How can I implement a thread-safe JSP page? What are the advantages and Disadvantages of using it?  

Answer:   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 

 

Question: How does JSP handle run-time exceptions?  

Answer:   You can use the errorPage attribute of the page directive to have uncaught run-time exceptions automatically forwarded to an error processing page. For example:

<%@ page errorPage="error.jsp" %>

redirects the browser to the JSP page error.jsp if an uncaught exception is encountered during request processing. Within error.jsp, if you indicate that it is an error-processing page, via the directive:

<%@ page isErrorPage="true" %>

the Throwable object describing the exception may be accessed within the error page via the exception implicit object.

Note: You must always use a relative URL as the value for the errorPage attribute. 

 

Question: How do I prevent the output of my JSP or Servlet pages from being cached by the browser?  

Answer:   You will need to set the appropriate HTTP header attributes to prevent the dynamic content output by the JSP page from being cached by the browser. Just execute the following scriptlet at the beginning of your JSP pages to prevent them from being cached at the browser. You need both the statements to take care of some of the older browser versions.

<%

response.setHeader("Cache-Control","no-store"); //HTTP 1.1

response.setHeader("Pragma","no-cache"); //HTTP 1.0

response.setDateHeader ("Expires", 0); //prevents caching at the proxy server

%>

 

 

Question: How do I use comments within a JSP page?  

Answer:   You can use "JSP-style" comments to selectively block out code while debugging or simply to comment your scriptlets. JSP comments are not visible at the client. For example:

<%-- the scriptlet is now commented out

<%

out.println("Hello World");

%>

--%>

You can also use HTML-style comments anywhere within your JSP page. These comments are visible at the client. For example:

<!-- (c) 2004 javagalaxy.com -->

Of course, you can also use comments supported by your JSP scripting language within your scriptlets. For example, assuming Java is the scripting language, you can have:

<%

//some comment

/**

yet another comment

**/

%>

 

 

Question: Response has already been commited error. What does it mean?  

Answer:   This error show only when you try to redirect a page after you already have written something in your page. This happens because HTTP specification force the header to be set up before the lay out of the page can be shown (to make sure of how it should be displayed...content-type="text/html" or "text/xml" or "plain-text" or "image/jpg", etc...) When you try to send a redirect status (Number is line_status_402), your HTTP server cannot send it right now if it hasn't finished to set up the header. If not starter to set up the header, there are no problems, but if it 's already begin to set up the header, then your HTTP server expects these headers to be finished setting up and it cannot be the case if the stream of the page is not over... In this last case it's like you have a file started with <HTML Tag> <Some Headers> <Body> some output (like testing your variables...) ... and before you indicate that the file is over (and before the size of the page can be setted up in the header), you try to send a redirect status... It s simply impossible due to the specification of HTTP 1.0 and 1.1 

 

Question: How do I use a scriptlet to initialize a newly instantiated bean?  

Answer:   A jsp:useBean action may optionally have a body. If the body is specified, its contents will be automatically invoked when the specified bean is instantiated. Typically, the body will contain scriptlets or jsp:setProperty tags to initialize the newly instantiated bean, although you are not restricted to using those alone.

The following example shows the "today" property of the Foo bean initialized to the current date when it is instantiated. Note that here, we make use of a JSP expression within the jsp:setProperty action.

<jsp:useBean id="foo" class="com.Bar.Foo" >

<jsp:setProperty name="foo" property="today" value="<%=java.text.DateFormat.getDateInstance().format(new java.util.Date()) %>"/ >

<%-- scriptlets calling bean setter methods go here --%>

</jsp:useBean > 

 

Question: How can I enable session tracking for JSP pages if the browser has disabled cookies?  

Answer:   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());

 

 

Question: How can I declare methods within my JSP page?  

Answer:   You can declare methods for use within your JSP page as declarations. The methods can then be invoked within any other methods you declare, or within JSP scriptlets and expressions.

Do note that you do not have direct access to any of the JSP implicit objects like request, response, session and so forth from within JSP methods. However, you should be able to pass any of the implicit JSP variables as parameters to the methods you declare. For example:

<%!

public String whereFrom(HttpServletRequest req) {

HttpSession ses = req.getSession();

...

return req.getRemoteHost();

}

%>

<%

out.print("Hi there, I see that you are coming in from ");

%>

<%= whereFrom(request) %>

Another Example

file1.jsp:

<%@page contentType="text/html"%>

<%!

public void test(JspWriter writer) throws IOException{

writer.println("Hello!");

}

%>

 

file2.jsp

<%@include file="file1.jsp"%>

<html>

<body>

<%test(out);% >

</body>

</html> 

 

Question: Is there a way I can set the inactivity lease period on a per-session basis?  

Answer:   Typically, a default inactivity lease period for all sessions is set within your JSP engine admin screen or associated properties file. However, if your JSP engine supports the Servlet 2.1 API, you can manage the inactivity lease period on a per-session basis. This is done by invoking the HttpSession.setMaxInactiveInterval() method, right after the session has been created. For example:

<%

session.setMaxInactiveInterval(300);

%>

would reset the inactivity period for this session to 5 minutes. The inactivity interval is set in seconds. 

 

Question: How can I set a cookie and delete a cookie from within a JSP page?  

Answer:   A cookie, mycookie, can be deleted using the following scriptlet:

<%

//creating a cookie

Cookie mycookie = new Cookie("aName","aValue");

response.addCookie(mycookie);

//delete a cookie

Cookie killMyCookie = new Cookie("mycookie", null);

killMyCookie.setMaxAge(0);

killMyCookie.setPath("/");

response.addCookie(killMyCookie);

%> 

 

Question: How does a servlet communicate with a JSP page?  

Answer:   The following code snippet shows how a servlet instantiates a bean and initializes it with FORM data posted by a browser. The bean is then placed into the request, and the call is then forwarded to the JSP page, Bean1.jsp, by means of a request dispatcher for downstream processing.

public void doPost (HttpServletRequest request, HttpServletResponse response) {

try {

govi.FormBean f = new govi.FormBean();

String id = request.getParameter("id");

f.setName(request.getParameter("name"));

f.setAddr(request.getParameter("addr"));

f.setAge(request.getParameter("age"));

//use the id to compute

//additional bean properties like info

//maybe perform a db query, etc.

// . . .

f.setPersonalizationInfo(info);

request.setAttribute("fBean",f);

getServletConfig().getServletContext().getRequestDispatcher ("/jsp/Bean1.jsp").forward(request, response);

} catch (Exception ex) {

. . .

}

}

The JSP page Bean1.jsp can then process fBean, after first extracting it from the default request scope via the useBean action.

jsp:useBean id="fBean" class="govi.FormBean" scope="request"/ jsp:getProperty name="fBean" property="name" / jsp:getProperty name="fBean" property="addr" / jsp:getProperty name="fBean" property="age" / jsp:getProperty name="fBean" property="personalizationInfo" / 

 

Question: How do I have the JSP-generated servlet subclass my own custom servlet class, instead of the default?  

Answer:   One should be very careful when having JSP pages extend custom servlet classes as opposed to the default one generated by the JSP engine. In doing so, you may lose out on any advanced optimization that may be provided by the JSP engine. In any case, your new superclass has to fulfill the contract with the JSP engine by:

Implementing the HttpJspPage interface, if the protocol used is HTTP, or implementing JspPage otherwise Ensuring that all the methods in the Servlet interface are declared final Additionally, your servlet superclass also needs to do the following:

The service() method has to invoke the _jspService() method

The init() method has to invoke the jspInit() method

The destroy() method has to invoke jspDestroy()

If any of the above conditions are not satisfied, the JSP engine may throw a translation error.

Once the superclass has been developed, you can have your JSP extend it as follows:

<%@ page extends="packageName.ServletName" %< 

 

Question: How can I prevent the word "null" from appearing in my HTML input text fields when I populate them with a resultset that has null values?  

Answer:   You could make a simple wrapper function, like

<%!

String blanknull(String s) {

return (s == null) ? "" : s;

}

%>

then use it inside your JSP form, like

<input type="text" name="shoesize" value="<%=blanknull(shoesize)% >" > 

 

Question: How can I get to print the stacktrace for an exception occuring within my JSP page?  

Answer:   By printing out the exception's stack trace, you can usually diagonse a problem better when debugging JSP pages. By looking at a stack trace, a programmer should be able to discern which method threw the exception and which method called that method. However, you cannot print the stacktrace using the JSP out implicit variable, which is of type JspWriter. You will have to use a PrintWriter object instead. The following snippet demonstrates how you can print a stacktrace from within a JSP error page:

<%@ page isErrorPage="true" %>

<%

out.println("

");

 PrintWriter pw = response.getWriter();

 exception.printStackTrace(pw);

 

out.println("

");

%> 

 

Question: How do you pass an InitParameter to a JSP?  

Answer:   The JspPage interface defines the jspInit() and jspDestroy() method which the page writer can use in their pages and are invoked in much the same manner as the init() and destory() methods of a servlet. The example page below enumerates through all the parameters and prints them to the console.

<%@ page import="java.util.*" %>

<%!

ServletConfig cfg =null;

public void jspInit(){

ServletConfig cfg=getServletConfig();

for (Enumeration e=cfg.getInitParameterNames(); e.hasMoreElements();) {

String name=(String)e.nextElement();

String value = cfg.getInitParameter(name);

System.out.println(name+"="+value);

}

}

%> 

 

Question: How can my JSP page communicate with an EJB Session Bean?  

Answer:   The following is a code snippet that demonstrates how a JSP page can interact with an EJB session bean:

<%@ page import="javax.naming.*, javax.rmi.PortableRemoteObject, foo.AccountHome, foo.Account" %>

<%!

//declare a "global" reference to an instance of the home interface of the session bean

AccountHome accHome=null;

public void jspInit() {

//obtain an instance of the home interface

InitialContext cntxt = new InitialContext( );

Object ref= cntxt.lookup("java:comp/env/ejb/AccountEJB");

accHome = (AccountHome)PortableRemoteObject.narrow(ref,AccountHome.class);

}

%>

<%

//instantiate the session bean

Account acct = accHome.create();

//invoke the remote methods

acct.doWhatever(...);

// etc etc...

%> 

 

 

Question: How can my application get to know when a HttpSession is removed?  

Answer:   Define a Class HttpSessionNotifier which implements HttpSessionBindingListener and implement the functionality what you need in valueUnbound() method.

Create an instance of that class and put that instance in HttpSession. 

 

Question: How do I include static files within a JSP page?  

Answer:   Static resources should always be included using the JSP include directive. This way, the inclusion is performed just once during the translation phase. The following example shows the syntax: Do note that you should always supply a relative URL for the file attribute. Although you can also include static resources using the action, this is not advisable as the inclusion is then performed for each and every request. 

 

Question: What is a output comment?

Answer: 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 -->

Question: What is a Hidden Comment?
Answer: A comments that documents the JSP page but is not sent to the client. The JSP engine ignores a hidden comment, and does not process any code within hidden comment tags. A hidden comment is not sent to the client, either in the displayed JSP page or the HTML page source. The hidden comment is useful when you want to hide or "comment out" part of your JSP page.

You can use any characters in the body of the comment except the closing --%> combination. If you need to use --%> in your comment, you can escape it by typing --%\>.

JSP Syntax

<%-- comment --%>

Examples

<%@ page language="java" %>

<html>

<head><title>A Hidden Comment </title></head>

<body>

<%-- This comment will not be visible to the colent in the page source --%>

</body>

</html>

Question: What is a Expression?
Answer: 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

Question: What is a Declaration?
Answer: 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; %>

Question: What is a Scriptlet?
Answer: 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.

Question: What are implicit objects? List them?
Answer: Certain objects that are available for the use in JSP documents without being declared first. These objects are parsed by the JSP engine and inserted into the generated servlet. The implicit objects re listed below

request

response

pageContext

session

application

out

config

page

exception

Question: Difference between forward and sendRedirect?
Answer: When you invoke a forward request, the request is sent to another resource on the server, without the client being informed that a different resource is going to process the request. This process occurs completly with in the web container. When a sendRedirtect method is invoked, it causes the web container to return to the browser indicating that a new URL should be requested. Because the browser issues a completly new request any object that are stored as request attributes before the redirect occurs will be lost. This extra round trip a redirect is slower than forward.

Question: What are the different scope valiues for the <jsp:useBean>?
Answer: The different scope values for <jsp:useBean> are

1. page

2. request

3.session

4.application

Question: Explain the life-cycle mehtods in JSP?
Answer: THe generated servlet class for a JSP page implements the HttpJspPage interface of the javax.servlet.jsp package. Hte HttpJspPage interface extends the JspPage interface which inturn extends the Servlet interface of the javax.servlet package. the generated servlet class thus implements all the methods of the these three interfaces. The JspPage interface declares only two mehtods - jspInit() and jspDestroy() that must be implemented by all JSP pages regardless of the client-server protocol. However the JSP specification has provided the HttpJspPage interfaec specifically for the JSp pages serving HTTP requests. This interface declares one method _jspService().

The jspInit()- The container calls the jspInit() to initialize te servlet instance.It is called before any other method, and is called only once for a servlet instance.

The _jspservice()- The container calls the _jspservice() for each request, passing it the request and the response objects.

The jspDestroy()- The container calls this when it decides take the instance out of service. It is the last method called n the servlet instance.

 

Top


 

SERVLET

 

Question: What are the phases in JSP?   

Answer:   a) Translation phase ? conversion of JSP to a Servlet source, and then Compilation of servlet source into a class file. The translation phase is typically carried out by the JSP engine itself, when it receives an incoming request for the JSP page for the first time

b) init(), service() and destroy() method as usual as Servlets. 

 

Question: How many cookies can one set in the response object of the servlet? Also, are there any restrictions on the size of cookies?   

Answer:   If the client is using Netscape, the browser can receive and store 300 total cookies

4 kilobytes per cookie (including name)

20 cookies per server or domain

 

Question: What?s the difference between sendRedirect( ) and forward( ) methods?   

Answer:   A sendRedirect method creates a new request (it?s also reflected in browser?s URL ) where as forward method forwards the same request to the new target(hence the chnge is NOT reflected in browser?s URL).

The previous request scope objects are no longer available after a redirect because it results in a new request, but it?s available in forward.

SendRedirectis slower compared to forward. 

 

Question: Is there some sort of event that happens when a session object gets bound or unbound to the session?   

Answer:   HttpSessionBindingListener will hear the events When an object is added and/or remove from the session object, or when the session is invalidated, in which case the objects are first removed from the session, whether the session is invalidated manually or automatically (timeout). 

 

Question: What do the differing levels of bean storage (page, session, app) mean?   

Answer:   page life time - NO storage. This is the same as declaring the variable in a scriptlet and using it from there.

session life time - request.getSession(true).putValue "myKey", myObj);

application level ? getServletConfig().getServletContext().setAttribute("myKey ",myObj )

request level - The storage exists for the lifetime of the request, which may be forwarded between jsp's and servlets 

 

Question: Is it true that servlet containers service each request by creating a new thread? If that is true, how does a container handle a sudden dramatic surge in incoming requests without significant performance degradation?   

Answer:   The implementation depends on the Servlet engine. For each request generally, a new Thread is created. But to give performance boost, most containers, create and maintain a thread pool at the server startup time. To service a request, they simply borrow a thread from the pool and when they are done, return it to the pool.

For this thread pool, upper bound and lower bound is maintained. Upper bound prevents the resource exhaustion problem associated with unlimited thread allocation. The lower bound can instruct the pool not to keep too many idle threads, freeing them if needed. 

 

Question: Can I just abort processing a JSP?   

Answer:   Yes. Because your JSP is just a servlet method, you can just put (whereever necessary) a < % return; % > 

 

Question: What is URL Encoding and URL Decoding ?   

Answer:   URL encoding is the method of replacing all the spaces and other extra characters into their corresponding Hex Characters and Decoding is the reverse process converting all Hex Characters back their normal form.

For Example consider this URL, /ServletsDirectory/Hello'servlet/

When Encoded using URLEncoder.encode("/ServletsDirectory/Hello'servlet/") the output is

http%3A%2F%2Fwww.javacommerce.com%2FServlets+Directory%2FHello%27servlet%2FThis can be decoded back using

URLDecoder.decode("http%3A%2F%2Fwww.javacommerce.com%2FServlets+Directory%2FHello%27servlet%2F") 

 

Question: Do objects stored in a HTTP Session need to be serializable? Or can it store any object?   

Answer:   Yes, the objects need to be serializable, but only if your servlet container supports persistent sessions. Most lightweight servlet engines (like Tomcat) do not support this. However, many EJB-enabled servlet engines do. Even if your engine does support persistent sessions, it is usually possible to disable this feature. 

 

Question: What is the difference between session and cookie?   

Answer:   The difference between session and a cookie is two-fold.

1) session should work regardless of the settings on the client browser. even if users decide to forbid the cookie (through browser settings) session still works. there is no way to disable sessions from the client browser.

2) session and cookies differ in type and amount of information they are capable of storing.

Javax.servlet.http.Cookie class has a setValue() method that accepts Strings. javax.servlet.http.HttpSession has a setAttribute() method which takes a String to denote the name and java.lang.Object which means that HttpSession is capable of storing any java object. Cookie can only store String objects. 

 

Question: What is the difference between ServletContext and ServletConfig?   

Answer:   Both are interfaces.

The servlet engine implements the ServletConfig interface in order to pass configuration information to a servlet. The server passes an object that implements the ServletConfig interface to the servlet's init() method.

The ServletContext interface provides information to servlets regarding the environment in which they are running. It also provides standard way for servlets to write events to a log file. 

 

Question: What are the differences between GET and POST service methods?   

Answer:   A GET request is a request to get a resource from the server. Choosing GET as the "method" will append all of the data to the URL and it will show up in the URL bar of your browser. The amount of information you can send back using a GET is restricted as URLs can only be 1024 characters. A POST request is a request to post (to send) form data to a resource on the server. A POST on the other hand will (typically) send the information through a socket back to the webserver and it won't show up in the URL bar. You can send much more information to the server this way - and it's not restricted to textual data either. It is possible to send files and even binary data such as serialized Java objects! 

 

Question: What is the difference between GenericServlet and HttpServlet?   

Answer:   GenericServlet is for servlets that might not use HTTP, like for instance FTP service.As of only Http is implemented completely in HttpServlet.

The GenericServlet has a service() method that gets called when a client request is made. This means that it gets called by both incoming requests and the HTTP requests are given to the servlet as they are 

 

Question: What is HttpTunneling?   

Answer:   HTTP tunneling is used to encapsulate other protocols within the HTTP or HTTPS protocols. Normally the intra-network of an organization is blocked by a firewall and the network is exposed to the outer world only through a specific web server port , that listens for only HTTP requests. To use any other protocol, that by passes the firewall, the protocol is embedded in HTTP and send as HttpRequest. 

 

Question: What is Server Side Push and how is it implemented and when is it useful?   

Answer:   Server Side push is useful when data needs to change regularly on the clients application or browser, without intervention from client. Standard examples might include apps like Stock's Tracker, Current News etc. As such server cannot connect to client's application automatically. The mechanism used is, when client first connects to Server, (Either through login etc..), then Server keeps the TCP/IP connection open.

It's not always possible or feasible to keep the connection to Server open. So another method used is, to use the standard HTTP protocols ways of refreshing the page, which is normally supported by all browsers.

<META HTTP-EQUIV="Refresh" CONTENT="5;URL=/servlet/stockquotes/">

This will refresh the page in the browser automatically and loads the new data every 5 seconds. 

 

Question: Request parameter How to find whether a parameter exists in the request object?   

Answer:   1.boolean hasFoo = !(request.getParameter("foo") == null || request.getParameter("foo").equals(""));

2. boolean hasParameter = request.getParameterMap().contains(theParameter);

(which works in Servlet 2.3+) 

 

Question: How can I send user authentication information while makingURLConnection?   

Answer:   You'll want to use HttpURLConnection.setRequestProperty and set all the appropriate headers to HTTP authorization. 

 

Question: What is the Max amount of information that can be saved in a Session Object ?   

Answer:   As such there is no limit on the amount of information that can be saved in a Session Object. Only the RAM available on the server machine is the limitation. The only limit is the Session ID length(Identifier) , which should not exceed more than 4K. If the data to be store is very huge, then it's preferred to save it to a temporary file onto hard disk, rather than saving it in session. Internally if the amount of data being saved in Session exceeds the predefined limit, most of the servers write it to a temporary cache on Hard disk. 

 

Question: Can we use the constructor, instead of init(), to initialize servlet?   

Answer:   Yes , of course you can use the constructor instead of init(). There's nothing to stop you. But you shouldn't. The original reason for init() was that ancient versions of Java couldn't dynamically invoke constructors with arguments, so there was no way to give the constructur a ServletConfig. That no longer applies, but servlet containers still will only call your no-arg constructor. So you won't have access to a ServletConfig or ServletContext. 

 

Question: How can a servlet refresh automatically if some new data has entered the database?   

Answer:   You can use a client-side Refresh or Server Push 

 

Question: The code in a finally clause will never fail to execute, right?   

Answer:   Using System.exit(1); in try block will not allow finally code to execute. 

 

Top


 

EJB

Question: What are the main benefits of J2EE?  

Answer:   J2EE provides the following:

Faster solutions delivery time to market. J2EE uses "containers" to simplify development. J2EE containers provide for the separation of business logic from resource and lifecycle management, which means that developers can focus on writing business logic -- their value add -- rather than writing enterprise infrastructure. For example, the Enterprise JavaBeansTM (EJBTM) container (implemented by J2EE technology vendors) handles distributed communication, threading, scaling, transaction management, etc. Similarly, Java Servlets simplify web development by providing infrastructure for component, communication, and session management in a web container that is integrated with a web server.

Freedom of choice. J2EE technology is a set of standards that many vendors can implement. The vendors are free to compete on implementations but not on standards or APIs. Sun supplies a comprehensive J2EE Compatibility Test Suite (CTS) to J2EE licensees. The J2EE CTS helps ensure compatibility among the application vendors which helps ensure portability for the applications and components written for J2EE. J2EE brings Write Once, Run AnywhereTM (WORATM) to the server.

Simplified connectivity. J2EE technology makes it easier to connect the applications and systems you already have and bring those capabilities to the web, to cell phones, and to devices. J2EE offers Java Message Service for integrating diverse applications in a loosely coupled, asynchronous way. J2EE also offers CORBA support for tightly linking systems through remote method calls. In addition, J2EE 1.3 adds J2EE Connectors for linking to enterprise information systems such as ERP systems, packaged financial applications, and CRM applications.

By offering one platform with faster solution delivery time to market, freedom of choice, and simplified connectivity, J2EE helps IT by reducing TCO and simultaneously avoiding single-source for their enterprise software needs.

 

 

Question: Name a few Design Patterns used in J2ee applications  

Answer:   MVC, Front Controller, Session Facade, Data Access Object 

Question: What is the deployment order for the deployed server components in WebLogic server?  

Answer:   § JDBC Connection Pools

§ JDBC Multi Pools

§ JDCB Data Sources

§ JDBC Tx Data Sources

§ JMS Connection Factories

§ JMS Servers

§ Connector Components

§ EJB Components

§ Web App Components

--- An examination of the log file .,., 

 

Question: Why do the create() or find() method return the remote reference or a primary key only?  

Answer:   The EJB Specification prohibits this behavior, and the weblogic.ejbc compiler checks for this behavior and prohibits any polymorphic type of response from a create() or find() method.

The reason the create() and find() methods cannot return any object or primitive type is similar to the reason that regular constructors can be cast into the class itself or any of it?s super classes.

For example

A a = new A() or

A b = new B() where B is a child of A.

You cannot do, for example Vector v = new A(); 

 

Question: Which XML parser comes with WebLogic Server 6.1?  

Answer:   We bundle a parser, based on Apache's Xerces 1.3.1 parser, in WebLogic Server 6.1. In addition, we include a WebLogic proprietary high-performance non-validating parser that you can use for small to medium sized XML documents. The WebLogic XML Registry allows you to configure the parser you want to use for specific document types. 

 

Question: Can I use the getAttribute() and setAttribute() methods of Version 2.2 of the Java Servlet API to parse XML documents?  

Answer:   Yes. Use the setAttribute() method for SAX mode parsing and the getAttribute() method for DOM mode parsing. Using these methods in a Servlet, however, is a WebLogic-specific feature. This means that the Servlet may not be fully portable to other Servlet engines, so use the feature with caution. 

 

Question: How can I run multiple instances of the same servlet class in the same WebLogic Server instance?  

Answer:   If you want to run multiple instances, your servlet will have to implement the SingleThreadModel interface. An instance of a class that implements the SingleThreadModel interface is guaranteed not to be invoked by multiple threads simultaneously. Multiple instances of a SingleThreadModel interface are used to service simultaneous requests, each running in a single thread.

When designing your servlet, consider how you use shared resources outside of the servlet class such as file and database access. Because there are multiple instances of servlets that are identical, and may use exactly the same resources, there are still synchronization and sharing issues that must be resolved, even if you do implement the SingleThreadModel interface. 

 

 

Question: Are enterprise beans allowed to use Thread.sleep()?  

Answer:   Enterprise beans make use of the services provided by the EJB container, such as life-cycle management. To avoid conflicts with these services, enterprise beans are restricted from performing certain operations: Managing or synchronizing threads 

 

Question: Is it possible to write two EJB's that share the same Remote and Home interfaces, and have different bean classes? if so, what are the advantages/disadvantages?  

Answer:   It's certainly possible. In fact, there's an example that ships with the Inprise Application Server of an Account interface with separate implementations for CheckingAccount and SavingsAccount, one of which was CMP and one of which was BMP. 

 

Question: Is it possible to specify multiple JNDI names when deploying an EJB?  

Answer:   No. To achieve this you have to deploy your EJB multiple times each specifying a different JNDI name. 

 

Question: Is there any way to force an Entity Bean to store itself to the db? I don't wanna wait for the container to update the db, I want to do it NOW! Is it possible?  

Answer:   Specify the transaction attribute of the bean as RequiresNew. Then as per section 11.6.2.4 of the EJB v 1.1 spec EJB container automatically starts a new transaction before the method call. The container also performs the commit protocol before the method result is sent to the client. 

 

Question: I am developing a BMP Entity bean. I have noticed that whenever the create method is invoked, the ejbLoad() and the ejbStore() methods are also invoked. I feel that once my database insert is done, having to do a select and update SQL queries is major overhead. is this behavior typical of all EJB containers? Is there any way to suppress these invocations?  

Answer:   This is the default behaviour for EJB. The specification states that ejbLoad() will be called before every transaction and ejbStore() after every transaction. Each Vendor has optimizations, which are proprietary for this scenario. 

 

Question: Can an EJB send asynchronous notifications to its clients?  

Answer:   Asynchronous notification is a known hole in the first versions of the EJB spec. The recommended solution to this is to use JMS, which is becoming available in J2EE-compliant servers. The other option, of course, is to use client-side threads and polling. This is not an ideal solution, but it's workable for many scenarios. 

 

Question: How can I access EJB from ASP?  

Answer:   You can use the Java 2 Platform, Enterprise Edition Client Access Services (J2EETM CAS) COM Bridge 1.0, currently downloadable from http://developer.java.sun.com/developer/earlyAccess/j2eecas/ 

 

Question: Is there a guarantee of uniqueness for entity beans?  

Answer:   There is no such guarantee. The server (or servers) can instantiate as many instances of the same underlying Entity Bean (with the same PK) as it wants. However, each instance is guaranteed to have up-to-date data values, and be transactionally consistent, so uniqueness is not required. This allows the server to scale the system to support multiple threads, multiple concurrent requests, and multiple hosts. 

 

Question: How do the six transaction attributes map to isolation levels like "dirty read"? Will an attribute like "Required" lock out other readers until I'm finished updating?  

Answer:   The Transaction Attributes in EJB do not map to the Transaction Isolation levels used in JDBC. This is a common misconception. Transaction Attributes specify to the container when a Transaction should be started, suspended(paused) and committed between method invocations on Enterprise JavaBeans. For more details and a summary of Transaction Attributes refer to section 11.6 of the EJB 1.1 specification. 

 

Question: I have created a remote reference to an EJB in FirstServlet. Can I put the reference in a servlet session and use that in SecondServlet?  

Answer:   Yes. The EJB client (in this case your servlet) acquires a remote reference to an EJB from the Home Interface; that reference is serializable and can be passed from servlet to servlet. If it is a session bean, then the EJB server will consider your web client's servlet session to correspond to a single EJB session, which is usually (but not always) what you want. 

 

Question: Can the primary key in the entity bean be a Java primitive type such as int?  

Answer:   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) 

 

Question: What's new in the EJB 2.0 specification?  

Answer:   Following are the main features supported in EJB 2.0 * Integration of EJB with JMS * Message Driven Beans * Implement additional Business methods in Home interface which are not specific for bean instance. * EJB QL. 

 

Question: What is the need of Remote and Home interface. Why cant it be in one?  

Answer:   In a few words, I would say that the main reason is because there is a clear division of roles and responsabilities between the two interfaces.

The home interface is your way to communicate with the container, that is who is responsable of creating, locating even removing one or more beans.

The remote interface is your link to the bean, that will allow you to remotely access to all its methods and members.

As you can see there are two distinct elements (the container and the beans) and you need two different interfaces for accessing to both of them. 

 

Question: What is the difference between Java Beans and EJB?s?  

Answer:   Java Beans are client-side objects and EJBs are server side object, and they have completely different development, lifecycle, purpose. 

 

Question: Question: With regard to Entity Beans, what happens if both my EJB Server and Database crash, what will happen to unsaved changes? Is there any transactional log file used?  

Answer:   Actually, if your EJB server crashes, you will not even be able to make a connection to the server to perform a bean lookup, as the server will no longer be listening on the port for incoming JNDI lookup requests. You will lose any data that wasn't committed prior to the crash. This is where you should start looking into clustering your EJB server.

Another Answer:

Hi, Any unsaved and uncommited changes are lost the moment your EJB Server crashes. If your database also crashes, then all the saved changes are also lost unless you have some backup or some recovery mechanism to retrieve the data. So consider database replication and EJB Clustering for such scenarios, though the occurence of such a thing is very very rare. Thx, Uma All databse have the concept of log files(for exampe oracle have redo log files concept). So if data bases crashes then on starting up they fill look up the log files to perform all pending jobs. But is EJB crashes, It depend upon the container how frequenlty it passivates or how frequesntly it refreshes the data with Database. 

 

Question: Question: Can you control when passivation occurs?  

Answer:   The developer, according to the specification, cannot directly control when passivation occurs. Although for Stateful Session Beans, the container cannot passivate an instance that is inside a transaction. So using transactions can be a a strategy to control passivation.

The ejbPassivate() method is called during passivation, so the developer has control over what to do during this exercise and can implement the require optimized logic.

Some EJB containers, such as BEA WebLogic, provide the ability to tune the container to minimize passivation calls.

Taken from the WebLogic 6.0 DTD -

"The passivation-strategy can be either "default" or "transaction". With the default setting the container will attempt to keep a working set of beans in the cache. With the "transaction" setting, the container will passivate the bean after every transaction (or method call for a non-transactional invocation)." 

 

Question: The EJB specification says that we cannot use Bean Managed Transaction in Entity Beans. Why?  

Answer:   The short, practical answer is... because it makes your entity beans useless as a reusable component. Also, transaction management is best left to the application server - that's what they're there for. It's all about atomic operations on your data. If an operation updates more than one entity then you want the whole thing to succeed or the whole thing to fail, nothing in between. If you put commits in the entity beans then it's very difficult to rollback if an error occurs at some point late in the operation. 

 

Question: Can I invoke Runtime.gc() in an EJB?  

Answer:   You shouldn't.

What will happen depends on the implementation, but the call will most likely be ignored. You should leave system level management like garbage collection for the container to deal with. After all, that's part of the benefit of using EJBs, you don't have to manage resources yourself. 

 

Question: What is clustering? What are the different algorithms used for clustering?  

Answer:   Clustering is grouping machines together to transparantly provide enterprise services.The client does not now the difference between approaching one server or approaching a cluster of servers.Clusters provide two benefits: scalability and high availability. Further information can be found in the JavaWorld article J2EE Clustering. 

 

Question: 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?  

Answer:   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. 

 

Question: What is the role of serialization in EJB?  

Answer:   A big part of EJB is that it is a framework for underlying RMI: remote method invocation. You're invoking methods remotely from JVM space 'A' on objects which are in JVM space 'B' -- possibly running on another machine on the network.

To make this happen, all arguments of each method call must have their current state plucked out of JVM 'A' memory, flattened into a byte stream which can be sent over a TCP/IP network connection, and then deserialized for reincarnation on the other end in JVM 'B' where the actual method call takes place.

If the method has a return value, it is serialized up for streaming back to JVM A. Thus the requirement that all EJB methods arguments and return values must be serializable. The easiest way to do this is to make sure all your classes implement java.io.Serializable. 

 

Question: What is EJB QL?  

Answer:   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. 

 

Question: Why bean must not implement the remote interface XARB  

Answer:   Asking 

 

Question: Does EJB 1.1 support mandate the support for RMI-IIOP ? What is the meaning of "the client API must support the Java RMI-IIOP programming model for portability, but the underlying protocol can be anything" ?  

Answer:   EJB1.1 does mandate the support of RMI-IIOP.

OK, to answer the second question:

There are 2 types of implementations that an EJB Server might provide: CORBA-based EJB Servers and Proprietry EJB Servers. Both support the RMI-IIOP API but how that API is implemented is a different story. (NB: By API we mean the interface provided to the client by the stub or proxy).

A CORBA-based EJB Server actually implements its EJB Objects as CORBA Objects (it therefore encorporates an ORB and this means that EJB's can be contacted by CORBA clients (as well as RMI-IIOP clients)

A proprietry EJB still implements the RMI-IIOP API (in the client's stub) but the underlying protocol can be anything. Therefore your EJB's CANNOT be contacted by CORBA clients. The difference is that in both cases, your clients see the same API (hence, your client portability) BUT how the stubs communicate with the server is different.

 

 

Question: What technologies are included in J2EE?  

Answer:   The primary technologies in J2EE are: Enterprise JavaBeansTM (EJBsTM), JavaServer PagesTM (JSPsTM), Java Servlets, the Java Naming and Directory InterfaceTM (JNDITM), the Java Transaction API (JTA), CORBA, and the JDBCTM data access API. 

 

Question: What is the Java Authentication and Authorization Service (JAAS) 1.0?  

Answer:   The Java Authentication and Authorization Service (JAAS) provides a way for a J2EE application to authenticate and authorize a specific user or group of users to run it. JAAS is a Java programing language version of the standard Pluggable Authentication Module (PAM) framework that extends the Java 2 platform security architecture to support user-based authorization. 

 

Question: Must my bean-managed persistence mechanism use the WebLogic JTS driver?  

Answer:   BEA recommend that you use the TxDataSource for bean-managed persistence. 

 

Question: Must EJBs be homogeneously deployed across a cluster? Why?  

Answer:   Yes. Beginning with WebLogic Server version 6.0, EJBs must be homogeneously deployed across a cluster for the following reasons:

n To keep clustering EJBs simple

n To avoid cross server calls which results in more efficiency. If EJBs are not deployed on all servers, cross server calls are much more likely.

n To ensure that every EJB is available locally

n To ensure that all classes are loaded in an undeployable way

Every server must have access to each EJB's classes so that it can be bound into the local JNDI tree. If only a subset of the servers deploys the bean, the other servers will have to load the bean's classes in their respective system classpaths which makes it impossible to undeploy the beans. 

 

Question: Is an XSLT processor bundled in WebLogic Server?  

Answer:   Yes, we bundle an XSLT processor, based on Apache's Xalan 2.0.1 processor, in WebLogic Server 6.1. 

 

Question: I plugged in a version of Apache Xalan that I downloaded from the Apache Web site, and now I get errors when I try to transform documents. What is the problem?  

Answer:   You must ensure that the version of Apache Xalan you download from the Apache Web site is compatible with Apache Xerces version 1.3.1. Because you cannot plug in a different version of Apache Xerces (see the preceding question), the only version of Apache Xerces that is compatible with WebLogic Server 6.1 is 1.3.1.

The built-in parser (based on version 1.3.1 of Apache Xerces) and transformer (based on version 2.0.1 of Apache Xalan) have been modified by BEA to be compatible with each other. 

 

Question: How do I increase WebLogic Server memory?  

Answer:   Increase the allocation of Java heap memory for WebLogic Server. (Set the minimum and the maximum to the same size.) Start WebLogic Server with the -ms32m option to increase the allocation, as in this example:

$ java ... -ms32m -mx32m ...

This allocates 32 megabytes of Java heap memory to WebLogic Server, which improves performance and allows WebLogic Server to handle more simultaneous connections. You can increase this value if necessary. 

 

Question: What causes Java.io exceptions in the log file of WebLogic Server?  

Answer:   You may see messages like these in the log file:

(Windows NT)

java.io.IOException Connection Reset by Peer

java.io.EOFException Connection Reset by Peer

(Solaris)

java.io.Exception: Broken pipe

These messages occur when you are using servlets. A client initiates an HTTP request, and then performs a series of actions on the browser:

1. Click Stop or enter equivalent command or keystrokes

2. Click Refresh or enter equivalent command or keystrokes

3. Send a new HTTP request.

The messages indicate that WebLogic Server has detected and recovered from an interrupted HTTP request. 

 

Question: What is the function of T3 in WebLogic Server?  

Answer:   T3 provides a framework for WebLogic Server messages that support for enhancements. These enhancements include abbreviations and features, such as object replacement, that work in the context of WebLogic Server clusters and HTTP and other product tunneling.

T3 predates Java Object Serialization and RMI, while closely tracking and leveraging these specifications. T3 is a superset of Java Object. Serialization or RMI; anything you can do in Java Object Serialization and RMI can be done over T3.

T3 is mandated between WebLogic Servers and between programmatic clients and a WebLogic Server cluster. HTTP and IIOP are optional protocols that can be used to communicate between other processes and WebLogic Server. It depends on what you want to do. For example, when you want to communicate between

n A browser and WebLogic Server-use HTTP

n An ORB and WebLogic Server-IIOP. 

 

Question: What are the enhancements in EJB 2.0 specification with respect to Asynchronous communication?  

Answer:   EJB 2.0 mandates integration between JMS and EJB.

We have specified the integration of Enterprise JavaBeans with the Java Message Service, and have introduced message-driven beans. A message-driven bean is a stateless component that is invoked by the container as a result of the arrival of a JMS message. The goal of the message-driven bean model is to make developing an enterprise bean that is asynchronously invoked to handle the processing of incoming JMS messages as simple as developing the same functionality in any other JMS MessageListener.  

 

Question: What are the enhancements in EJB 2.0 with respect to CMP?  

Answer:   EJB 2.0 extends CMP to include far more robust modeling capability, with support for declarative management of relationships between entity EJBs. Developers no longer need to re-establish relationships between the various beans that make up their application -- the container will restore the connections automatically as beans are loaded, allowing bean developers to navigate between beans much as they would between any standard Java objects.

EJB 2.0 also introduces for the first time a portable query language, based on the abstract schema, not on the more complex database schema. This provides a database and vendor-independent way to find entity beans at run time, based on a wide variety of search criteria. 

 

Question: Can you briefly describe about local interfaces?  

Answer:   EJB was originally designed around remote invocation using the Java Remote Method Invocation (RMI) mechanism, and later extended to support to standard CORBA transport for these calls using RMI/IIOP. This design allowed for maximum flexibility in developing applications without consideration for the deployment scenario, and was a strong feature in support of a goal of component reuse in J2EE.

Many developers are using EJBs locally -- that is, some or all of their EJB calls are between beans in a single container.

With this feedback in mind, the EJB 2.0 expert group has created a local interface mechanism. The local interface may be defined for a bean during development, to allow streamlined calls to the bean if a caller is in the same container. This does not involve the overhead involved with RMI like marshalling etc. This facility will thus improve the performance of applications in which co-location is planned.

Local interfaces also provide the foundation for container-managed relationships among entity beans with container-managed persistence. 

 

Question: What are the special design care that must be taken when you work with local interfaces?  

Answer:   It 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. 

 

Question: What happens if remove( ) is never invoked on a session bean?  

Answer:   In case of a stateless session bean it may not matter if we call or not as in both cases nothing is done. The number of beans in cache is managed by the container.

In case of stateful session bean, the bean may be kept in cache till either the session times out, in which case the bean is removed or when there is a requirement for memory in which case the data is cached and the bean is sent to free pool. 

 

Question: What is the difference between creating a distributed application using RMI and using a EJB architecture?  

Answer:   It is possible to create the same application using RMI and EJB. But in case of EJB the container provides the requisite services to the component if we use the proper syntax. It thus helps in easier development and lesser error and use of proven code and methodology. But the investment on application server is mandatory in that case. But this investment is warranted because it results in less complex and maintainable code to the client, which is what the end client wants. Almost all the leading application servers provide load balancing and performance tuning techniques. In case of RMI we have to code the services and include in the program the way to invoke these services. 

 

Question: Why would a client application use JTA transactions?   (JTA)

Answer:   One possible example would be a scenario in which a client needs to employ two (or more) session beans, where each session bean is deployed on a different EJB server and each bean performs operations against external resources (for example, a database) and/or is managing one or more entity beans. In this scenario, the client's logic could required an all-or-nothing guarantee for the operations performed by the session beans; hence, the session bean usage could be bundled together with a JTA UserTransaction object.

In the previous scenario, however, the client application developer should address the question of whether or not it would be better to encapsulate these operations in yet another session bean, and allow the session bean to handle the transactions via the EJB container. In general, lightweight clients are easier to maintain than heavyweight clients. Also, EJB environments are ideally suited for transaction management.

 

 ... Context c = new InitialContext(); UserTransaction ut = (UserTransaction)

c.lookup("java:comp/UserTransaction"); ut.begin(); // perform multiple operations... ut.commit() ...

 

 

Question: Can the bean class implement the EJBObject class directly? If not why?  

Answer:   It is better not to do it will make the Bean class a remote object and its methods can be accessed without the containers? security, and transaction implementations if our code by mistake passed it in one of its parameters. Its just a good design practice. 

 

Question: What does isIdentical() method return in case of different type of beans?  

Answer:   Stateless ? true always

Stateful ? depends whether the references point to the same session object

Entity ? Depends whether the primary key is the same and the home is same 

 

Question: How should you type cast a remote object? Why?  

Answer:   A client program that is intended to be interoperable with all compliant EJB Container implementations must use the javax.rmi.PortableRemoteObject.narrow(...) method to perform type-narrowing of the client-side representations of the remote home and remote interfaces. Programs using the cast operator for narrowing the remote and remote home interfaces are likely to fail if the Container implementation uses RMI-IIOP as the underlying communication transport. 

 

Question: What should you do in a passivate method?  

Answer:   You try to make all nontransient variables, which are not one of the following to null. For the given list the container takes care of serializing and restoring the object when activated.

Serializable objects, null, UserTransaction, SessionContext, JNDI contexts in the beans context, reference to other beans, references to connection pools.

Things that must be handled explicitly are like a open database connection etc. These must be closed and set to null and retrieved back in the activate method.

 

 

Question: What is the relationship between local interfaces and container-managed relationships?  

Answer:   Entity beans that have container-managed relationships with other entity beans, must be accessed in the same local scope as those related beans, and therefore typically provide a local client view. In order to be the target of a container-managed relationship, an entity bean with container-managed persistence must provide a local interface. 

 

Question: What does a remove method do for different cases of beans?  

Answer:   Stateless Session : Does not do anything to the bean as moving the bean from free pool to cache are managed by the container depending on load.

Stateful Session: Removes the bean from the cache.

Entity Bean: Deletes the bean (data) from persistent storage 

 

Question: How does a container-managed relationship work?  

Answer:   An entity bean accesses related entity beans by means of the accessor methods for its container-managed relationship fields, which are specified by the cmr-field elements of its abstract persistence schema defined in the deployment descriptor. Entity bean relationships are defined in terms of the local interfaces of the related beans, and the view an entity bean presents to its related beans is defined by its local home and local interfaces. Thus, an entity bean can be the target of a relationship from another entity bean only if it has a local interface. 

 

Question: What is the new basic requirement for a CMP entity bean class in 2.0 from that of ejb 1.1?  

Answer:   It must be abstract class. The container extends it and implements methods which are required for managing the relationships 

 

Question: What are the basic classes required in the client for invoking an EJB?  

Answer:   The home and the remote interfaces, the implementation of the Naming Context Factory, the stubs and skeletons.

In some App servers the stubs and the skeletons can be dynamically downloaded from the server 

 

Question: What is the difference between Message Driven Beans and Stateless Session beans?  

Answer:   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. 

 

Question: What are the benefits of Clustering (Workload Management)?  

Answer:   They are

1. It balances client processing requests, allowing incoming work requests to be distributed according to a configured Workload Management selection policy.

2. It provides fail over capability by redirecting client requests to a running server when one or more servers are unavailable. This improves the availability of applications and administrative services.

3. It enables systems to be scaled up to serve a higher client load than provided by the basic configuration. With server groups and clones additional instances of servers can easily be added to the configuration.

4. It enables servers to be transparently maintained and upgraded while applications remain available for users.

5. It centralizes administration of application servers and other objects. 

 

Question: What are the types of Scaling?  

Answer:   There are two types of scaling

1. Vertical Scaling

2. Horizontal Scaling. 

 

Question: What is Vertical Scaling?  

Answer:   When multiple server clones of an application server are defined on the same physical m/c, it is called Vertical Scaling. The objective is to use the processing power of that m/c more efficiently. 

 

Question: What is Horizontal Scaling?  

Answer:   When Clones of an application server are defined on multiple physical m/c, it is called Horizontal Scaling. The objective is to use more than one less powerful m/c more efficiently. 

 

Question: What is a Server Group?  

Answer:   A server group is a template of an Application Server(and its contents) i.e, it is a logical representation of the application server. It has the same structure and attributes as the real Application Server, but it is not associated with any node, and does not correspond to any real server process running on any node. 

 

Question: What is a Clone?  

Answer:   The copies of a server group are called Clones. But unlike a Server Group Clones are associated with a node and are real server process running in that node. 

 

Question: What is Ripple Effect?  

Answer:   The process of propagating the changes in the properties of a server group during runtime to all the associated clones is called Ripple Effect. 

 

Question: What level of Load Balancing is possible with EJBs?  

Answer:   The workload management service provides load balancing for the following types of enterprise beans

1. Homes of entity or session beans

2. Instances of entity beans

3. Instances of stateless session beans 

 

Question: What is the basic requirement for in-memory replication in Weblogic?  

Answer:   1. The data in session should consist only of Serialized objects.

2. Only setAttribute function should be used to set objects in session 

 

Question: How JDBC services can be used in clustered environment?  

Answer:   Identical DataSource has to be created in each clustered server instances and configure to use different connection pools. 

 

Question: What are the services that should not be used in a Clustered Environment?  

Answer:   Non-clustered services:

1. File Services

2. Time services

3. Weblogic events

4. Weblogic Workspaces (In WebLogic 5.1) 

 

Question: Mention some tools to cluster Web Servers?  

Answer:   Web Servers can be clustered using

1. Edge Server.

2. DNS 

 

Question: What is in-memory replication?  

Answer:   The process by which the contents in the memory of one physical m/c are replicated in all the m/c in the cluster is called in-memory replication. 

 

Question: How do you get Column names only for a table (SQL Server)? Write the Query.   (JDBC)

Answer:   select name from syscolumns where id=(select id from sysobjects where name='user_hdr') order by colid --user_hdr is the table name 

 

Question: What is the need for Clustering?  

Answer:   To scale the application so that it

1. Is Highly Available

2. Has High Throughput. 

 

Question: Is is possible for an EJB client to marshall an object of class java.lang.Class to an EJB?  

Answer:   Technically yes, spec. compliant NO! - The enterprise bean must not attempt to query a class to obtain information about the declared members that are not otherwise accessible to the enterprise bean because of the security rules of the Java language. 

 

Question: Is it legal to have static initializer blocks in EJB?  

Answer:   Although technically it is legal, static initializer blocks are used to execute some piece of code before executing any constructor or method while instantiating a class. Static initializer blocks are also typically used to initialize static fields - which may be illegal in EJB if they are read/write - In EJB this can be achieved by including the code in either the ejbCreate(), setSessionContext() or setEntityContext() methods. 

 

Question: How can I implement a thread-safe JSP page?  

Answer:   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. 

 

Question: Is it possible to stop the execution of a method before completion in a SessionBean?  

Answer:   Stopping the execution of a method inside a Session Bean is not possible without writing code inside the Session Bean. This is because you are not allowed to access Threads inside an EJB. 

 

Question: What is the default transaction attribute for an EJB?  

Answer:   There is no default transaction attribute for an EJB. Section 11.5 of EJB v1.1 spec says that the deployer must specify a value for the transaction attribute for those methods having container managed transaction. In weblogic, the default transaction attribute for EJB is SUPPORTS. 

 

Question: What is the difference between session and entity beans? When should I use one or the other?  

Answer:   An entity bean represents persistent global data from the database; a session bean represents transient user-specific data that will die when the user disconnects (ends his session). Generally, the session beans implement business methods (e.g. Bank.transferFunds) that call entity beans (e.g. Account.deposit, Account.withdraw) 

 

Question: Is there any default cache management system with Entity beans ? In other words whether a cache of the data in database will be maintained in EJB ?  

Answer:   Caching data from a database inside the Application Server are what Entity EJB's are used for.The ejbLoad() and ejbStore() methods are used to synchronize the Entity Bean state with the persistent storage(database). Transactions also play an important role in this scenario. If data is removed from the database, via an external application - your Entity Bean can still be "alive" the EJB container. When the transaction commits, ejbStore() is called and the row will not be found, and the transcation rolled back. 

 

Question: Why is ejbFindByPrimaryKey mandatory?  

Answer:   An Entity Bean represents persistent data that is stored outside of the EJB Container/Server. The ejbFindByPrimaryKey is a method used to locate and load an Entity Bean into the container, similar to a SELECT statement in SQL. By making this method mandatory, the client programmer can be assured that if they have the primary key of the Entity Bean, then they can retrieve the bean without having to create a new bean each time - which would mean creating duplications of persistent data and break the integrity of EJB. 

 

Question: Why do we have a remove method in both EJBHome and EJBObject?  

Answer:   With the EJBHome version of the remove, you are able to delete an entity bean without first instantiating it (you can provide a PrimaryKey object as a parameter to the remove method). The home version only works for entity beans. On the other hand, the Remote interface version works on an entity bean that you have already instantiated. In addition, the remote version also works on session beans (stateless and statefull) to inform the container of your loss of interest in this bean. 

 

Question: How can I call one EJB from inside of another EJB?  

Answer:   EJBs can be clients of other EJBs. It just works. Use JNDI to locate the Home Interface of the other bean, then acquire an instance reference, and so forth. 

 

Question: What is the difference between a Server, a Container, and a Connector?  

Answer:   An EJB server is an application, usually a product such as BEA WebLogic, that provides (or should provide) for concurrent client connections and manages system resources such as threads, processes, memory, database connections, network connections, etc.

An EJB container runs inside (or within) an EJB server, and provides deployed EJB beans with transaction and security management, etc. The EJB container insulates an EJB bean from the specifics of an underlying EJB server by providing a simple, standard API between the EJB bean and its container.

A Connector provides the ability for any Enterprise Information System (EIS) to plug into any EJB server which supports the Connector architecture. See http://java.sun.com/j2ee/connector/ for more indepth information on Connectors. 

 

Question: How is persistence implemented in enterprise beans?  

Answer:   Persistence in EJB is taken care of in two ways, depending on how you implement your beans: container managed persistence (CMP) or bean managed persistence (BMP)

For CMP, the EJB container which your beans run under takes care of the persistence of the fields you have declared to be persisted with the database - this declaration is in the deployment descriptor. So, anytime you modify a field in a CMP bean, as soon as the method you have executed is finished, the new data is persisted to the database by the container.

For BMP, the EJB bean developer is responsible for defining the persistence routines in the proper places in the bean, for instance, the ejbCreate(), ejbStore(), ejbRemove() methods would be developed by the bean developer to make calls to the database. The container is responsible, in BMP, to call the appropriate method on the bean. So, if the bean is being looked up, when the create() method is called on the Home interface, then the container is responsible for calling the ejbCreate() method in the bean, which should have functionality inside for going to the database and looking up the data. 

 

Question: What is an EJB Context?  

Answer:   EJBContext is an interface that is implemented by the container, and it is also a part of the bean-container contract. Entity beans use a subclass of EJBContext called EntityContext. Session beans use a subclass called SessionContext. These EJBContext objects provide the bean class with information about its container, the client using the bean and the bean itself. They also provide other functions. See the API docs and the spec for more details. 

 

Question: Is method overloading allowed in EJB?  

Answer:   Yes you can overload methods 

 

Question: Should synchronization primitives be used on bean methods?  

Answer:   No. The EJB specification specifically states that the enterprise bean is not allowed to use thread primitives. The container is responsible for managing concurrent access to beans at runtime 

 

Question: Question: Are we allowed to change the transaction isolation property in middle of a transaction?  

Answer:   No. You cannot change the transaction isolation level in the middle of transaction. 

 

Question: Question: For Entity Beans, What happens to an instance field not mapped to any persistent storage,when the bean is passivated?  

Answer:   The specification infers that the container never serializes an instance of an Entity bean (unlike stateful session beans). Thus passivation simply involves moving the bean from the "ready" to the "pooled" bin. So what happens to the contents of an instance variable is controlled by the programmer. Remember that when an entity bean is passivated the instance gets logically disassociated from it's remote object.

Be careful here, as the functionality of passivation/activation for Stateless Session, Stateful Session and Entity beans is completely different. For entity beans the ejbPassivate method notifies the entity bean that it is being disassociated with a particular entity prior to reuse or for dereferenc. 

 

Question: Question: What is a Message Driven Bean, What functions does a message driven bean have and how do they work in collaboration with JMS?  

Answer:   Message driven beans are the latest addition to the family of component bean types defined by the EJB specification. The original bean types include session beans, which contain business logic and maintain a state associated with client sessions, and entity beans, which map objects to persistent data.

Message driven beans will provide asynchrony to EJB based applications by acting as JMS message consumers. A message bean is associated with a JMS topic or queue and receives JMS messages sent by EJB clients or other beans.

Unlike entity beans and session beans, message beans do not have home or remote interfaces. Instead, message driven beans are instantiated by the container as required. Like stateless session beans, message beans maintain no client-specific state, allowing the container to optimally manage a pool of message-bean instances.

Clients send JMS messages to message beans in exactly the same manner as they would send messages to any other JMS destination. This similarity is a fundamental design goal of the JMS capabilities of the new specification.

To receive JMS messages, message driven beans implement the javax.jms.MessageListener interface, which defines a single "onMessage()" method.

When a message arrives, the container ensures that a message bean corresponding to the message topic/queue exists (instantiating it if necessary), and calls its onMessage method passing the client's message as the single argument. The message bean's implementation of this method contains the business logic required to process the message.

Note that session beans and entity beans are not allowed to function as message beans. 

 

Question: Does RMI-IIOP support code downloading for Java objects sent by value across an IIOP connection in the same way as RMI does across a JRMP connection?   (RMI)

Answer:   Yes. The JDK 1.2 support the dynamic class loading. 

 

Question: 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?  

Answer:   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.

Another Answer:

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 app server. How it is implemented, it is again up to the implementer. 

 

Question: What is the advantage of puttting an Entity Bean instance from the "Ready State" to "Pooled state"?  

Answer:   The idea of the "Pooled State" is to allow a container to maintain a pool of entity beans that has been created, but has not been yet "synchronized" or assigned to an EJBObject. This mean that the instances do represent entity beans, but they can be used only for serving Home methods (create or findBy), since those methods do not relay on the specific values of the bean. All these instances are, in fact, exactly the same, so, they do not have meaningful state. Jon Thorarinsson has also added: It can be looked at it this way:

If no client is using an entity bean of a particular type there is no need for cachig it (the data is persisted in the database).

Therefore, in such cases, the container will, after some time, move the entity bean from the "Ready State" to the "Pooled state" to save memory.

Then, to save additional memory, the container may begin moving entity beans from the "Pooled State" to the "Does Not Exist State", because even though the bean's cache has been cleared, the bean still takes up some memory just being in the "Pooled State". 

 

Question: Can a Session Bean be defined without ejbCreate() method?  

Answer:   The ejbCreate() methods is part of the bean's lifecycle, so, the compiler will not return an error because there is no ejbCreate() method.

However, the J2EE spec is explicit:

the home interface of a Stateless Session Bean must have a single create() method with no arguments, while the session bean class must contain exactly one ejbCreate() method, also without arguments.

Stateful Session Beans can have arguments (more than one create method) stateful beans can contain multiple ejbCreate() as long as they match with the home interface definition

You need a reference to your EJBObject to startwith. For that Sun insists on putting a method for creating that reference (create method in the home interface). The EJBObject does matter here. Not the actual bean. 

 

Question: 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?  

Answer:   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 (1)" 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. (1) Core J2EE design patterns (2001) 

 

Question: Is there any way to read values from an entity bean without locking it for the rest of the transaction (e.g. read-only transactions)? We have a key-value map bean which deadlocks during some concurrent reads. Isolation levels seem to affect the database only, and we need to work within a transaction.  

Answer:   The only thing that comes to (my) mind is that you could write a 'group accessor' - a method that returns a single object containing all of your entity bean's attributes (or all interesting attributes). This method could then be placed in a 'Requires New' transaction. This way, the current transaction would be suspended for the duration of the call to the entity bean and the entity bean's fetch/operate/commit cycle will be in a separate transaction and any locks should be released immediately. Depending on the granularity of what you need to pull out of the map, the group accessor might be overkill. 

 

Question: What is the difference between a "Coarse Grained" Entity Bean and a "Fine Grained" Entity Bean?  

Answer:   A 'fine grained' entity bean is pretty much directly mapped to one relational table, in third normal form.

A 'coarse grained' entity bean is larger and more complex, either because its attributes include values or lists from other tables, or because it 'owns' one or more sets of dependent objects. Note that the coarse grained bean might be mapped to a single table or flat file, but that single table is going to be pretty ugly, with data copied from other tables, repeated field groups, columns that are dependent on non-key fields, etc.

Fine grained entities are generally considered a liability in large systems because they will tend to increase the load on several of the EJB server's subsystems (there will be more objects exported through the distribution layer, more objects participating in transactions, more skeletons in memory, more EJB Objects in memory, etc.) The other side of the coin is that the 1.1 spec doesn't mandate CMP Error! No index entries found.support for dependent objects (or even indicate how they should be supported), which makes it more difficult to do coarse grained objects with CMP. The EJB 2.0 specification improves this in a huge way. 

 

Question: What is EJBDoclet?  

Answer:   EJBDoclet is an open source JavaDoc doclet that generates a lot of the EJB related source files from custom JavaDoc comments tags embedded in the EJB source file. 

 

Top


 

JNDI, JMS

 

Question: What is messaging?  

Answer:   Messaging is a mechanism by which data can be passed from one application to another application. 

 

Question: What is point-to-point messaging?  

Answer:   With point-to-point message passing the sending application/client establishes a named message queue in the JMS broker/server and sends messages to this queue. The receiving client registers with the broker to receive messages posted to this queue. There is a one-to-one relationship between the sending and receiving clients.  

 

 

Question: Can two different JMS services talk to each other? For instance, if A and B are two different JMS providers, can Provider A send messages directly to Provider B? If not, then can a subscriber to Provider A act as a publisher to Provider B?  

Answer:   The answers are no to the first question and yes to the second. The JMS specification does not require that one JMS provider be able to send messages directly to another provider. However, the specification does require that a JMS client must be able to accept a message created by a different JMS provider, so a message received by a subscriber to Provider A can then be published to Provider B. One caveat is that the publisher to Provider B is not required to handle a JMSReplyTo header that refers to a destination that is specific to Provider A. 

 

Question: What is the advantage of persistent message delivery compared to nonpersistent delivery?  

Answer:   If the JMS server experiences a failure, for example, a power outage, any message that it is holding in primary storage potentially could be lost. With persistent storage, the JMS server logs every message to secondary storage. (The logging occurs on the front end, that is, as part of handling the send operation from the message producing client.) The logged message is removed from secondary storage only after it has been successfully delivered to all consuming clients 

 

Question: How is a java object message delivered to a non-java Client?  

Answer:   It is according to the specification that the message sent should be received in the same format. A non-java client cannot receive a message in the form of java object. The provider in between handles the conversion of the data type and the message is transferred to the other end. 

 

Question: What is MDB and What is the special feature of that?  

Answer:   MDB is Message driven bean, which very much resembles the Stateless session bean. The incoming and out going messages can be handled by the Message driven bean. The ability to communicate asynchronously is the special feature about the Message driven bean. 

 

Question: Give an example of using the publish/subscribe model.  

Answer:   JMS can be used to broadcast shutdown messages to clients connected to the Weblogic server on a module wise basis. If an application has six modules, each module behaves like a subscriber to a named topic on the server. 

 

Question: What is the difference between the Mailing and Messaging?  

Answer:   Java Mailing is the set of APIs that primarily concerns with the sending of Mail messages through the standard mail protocols. Messaging is the way of communicating to the remote machines using Message Oriented Middlewares. Message Oriented Middlewares do not use mailing internally for communication. They create their own channels for communication. 

 

 

Question: What are the types of messaging?  

Answer:   There are two kinds of Messaging.

Synchronous Messaging:

Synchronous messaging involves a client that waits for the server to respond to a message.

Asynchronous Messaging:

Asynchronous messaging involves a client that does not wait for a message from the server. An event is used to trigger a message from a server. 

 

Question: What is publish/subscribe messaging?  

Answer:   With publish/subscribe message passing the sending application/client establishes a named topic in the JMS broker/server and publishes messages to this queue. The receiving clients register (specifically, subscribe) via the broker to messages by topic; every subscriber to a topic receives each message published to that topic. There is a one-to-many relationship between the publishing client and the subscribing clients. 

 

Question: Why doesn't the JMS API provide end-to-end synchronous message delivery and notification of delivery?  

Answer:   Some messaging systems provide synchronous delivery to destinations as a mechanism for implementing reliable applications. Some systems provide clients with various forms of delivery notification so that the clients can detect dropped or ignored messages. This is not the model defined by the JMS API.

JMS API messaging provides guaranteed delivery via the once-and-only-once delivery semantics of PERSISTENT messages. In addition, message consumers can insure reliable processing of messages by using either CLIENT_ACKNOWLEDGE mode or transacted sessions. This achieves reliable delivery with minimum synchronization and is the enterprise messaging model most vendors and developers prefer.

The JMS API does not define a schema of systems messages (such as delivery notifications). If an application requires acknowledgment of message receipt, it can define an application-level acknowledgment message. 

 

Question: What are the core JMS-related objects required for each JMS-enabled application?  

Answer:   Each JMS-enabled client must establish the following:

· A connection object provided by the JMS server (the message broker)

· Within a connection, one or more sessions, which provide a context for message sending and receiving

· Within a session, either a queue or topic object representing the destination (the message staging area) within the message broker

· Within a session, the appropriate sender or publisher or receiver or subscriber object (depending on whether the client is a message producer or consumer and uses a point-to-point or publish/subscribe strategy, respectively)

Within a session, a message object (to send or to receive) 

 

Question: What are the various message types supported by JMS?  

Answer:   Stream Messages ? Group of Java Primitives

Map Messages ? Name Value Pairs.

Name being a string

Value being a java primitive

Text Messages ? String messages (since being widely used a separate messaging Type has been supported)

Object Messages ? Group of serialize able java object

Bytes Message ? Stream of uninterrupted bytes

 

 

Question: What is the Role of the JMS Provider?  

Answer:   The JMS provider handles security of the messages, data conversion and the client triggering. The JMS provider specifies the level of encryption and the security level of the message, the best data type for the non-JMS client. 

 

Question: How does a typical client perform the communication?  

Answer:   1. Use JNDI to locate administrative objects.

1a. Locate a single ConnectionFactory object.

1b. Locate one or more Destination objects.

2. Use the ConnectionFactory to create a JMS Connection.

3. Use the Connection to create one or more Session(s).

4. Use a Session and the Destinations to create the MessageProducers and MessageConsumers needed.

5. Perform your communication. 

 

Question: Give an example of using the point-to-point model.  

Answer:   The point-to-point model is used when the information is specific to a single client. For example, a client can send a message for a print out, and the server can send information back to this client after completion of the print job. 

 

Question: How does the Application server handle the JMS Connection?  

Answer:   - App server creates the server session and stores them in a pool

- Connection consumer uses the server session to put messages in the session of the JMS.

- Server session is the one that spawns the JMS session.

- Applications written by Application programmers creates the message listener

 

 

Question: What protocols does JNDI provide an interface to?   

Answer:   JNDI itself is independent of any specific directory access protocol. Individual service providers determine the protocols to support. JNDI supports popular protocols, such as LDAP (Light weight Directory Access Protocol) , NDS(Netscape Directory Service), DNS(Domain Naming Service), and NIS(Network Information Service), supplied by different vendors. 

 

Question: What is Context and InitialContext?   

Answer:   A context represents a set of bindings within a naming service. A Context object provides the methods for binding names to objects and unbinding names from objects, for renaming objects, and for listing the bindings. JNDI performs all naming operations relative to a context.

The JNDI specification defines an InitialContext class. This class is instantiated with properties that define the type of naming service in use (such as provider URL, security, ID and password to use when connecting). 

 

 

Question: What's the difference between JNDI lookup(), list(), listBindings(), and search()?   

Answer:   lookup() attempts to find the specified object in the given context. I.e., it looks for a single, specific object and either finds it in the current context or it fails.

list() attempts to return an enumeration of all of the NameClassPair's of all of the objects in the current context. I.e., it's a listing of all of the objects in the current context but only returns the object's name and the name of the class to which the object belongs.

listBindings() attempts to return an enumeration of the Binding's of all of the objects in the current context. I.e., it's a listing of all of the objects in the current context with the object's name, its class name, and a reference to the object itself.

search() attempts to return an enumeration of all of the objects matching a given set of search criteria. It can search across multiple contexts (or not). It can return whatever attributes of the objects that you desire. Etc. It's by far the most complex and powerful of these options but is also the most expensive.

 

 

Question: Components of JNDI   

Answer:   Naming Interface- The naming interface organizes information hierarchically and maps human-friendly names to addresses or objects that are machine-friendly. It allows access to named objects through multiple namespaces.

Directory Interface- JNDI includes a directory service interface that provides access to directory objects, which can contain attributes, thereby providing attribute-based searching and schema support

Service Provider Interface- JNDI comes with the SPI, which supports the protocols provided by third parties.

 

Top


 

 

RMI, JDBC, XML

 

Question: What is the query used to display all tables names in SQL Server (Query analyzer)?   (JDBC)

Answer:   select * from information_schema.tables 

 

 

Question: How many types of JDBC Drivers are present and what are they?   

Answer:   There are 4 types of JDBC Drivers

Type 1: JDBC-ODBC Bridge Driver

Type 2: Native API Partly Java Driver

Type 3: Network protocol Driver

Type 4: JDBC Net pure Java Driver 

 

Question: What is the fastest type of JDBC driver?   

Answer:   JDBC driver performance will depend on a number of issues:

(a) the quality of the driver code,

(b) the size of the driver code,

(c) the database server and its load,

(d) network topology,

(e) the number of times your request is translated to a different API.

In general, all things being equal, you can assume that the more your request and response change hands, the slower it will be. This means that Type 1 and Type 3 drivers will be slower than Type 2 drivers (the database calls are make at least three translations versus two), and Type 4 drivers are the fastest (only one translation). 

 

 

Question: Is the JDBC-ODBC Bridge multi-threaded?   

Answer:   No. The JDBC-ODBC Bridge does not support concurrent access from different threads. The JDBC-ODBC Bridge uses synchronized methods to serialize all of the calls that it makes to ODBC. Multi-threaded Java programs may use the Bridge, but they won't get the advantages of multi-threading. 

 

Question: Does the JDBC-ODBC Bridge support multiple concurrent open statements per connection?   

Answer:   No. You can open only one Statement object per connection when you are using the JDBC-ODBC Bridge

 

Question: What is cold backup, hot backup, warm backup recovery?   

Answer:   a. cold backup - All these files must be backed up at the same time, before the databaseis restarted.

b. hot backup - official name is 'online backup' ? is a backup taken of each tablespace while the database is running and is being accessed by the users. 

 

Question: When we will Denormalize data?   

Answer:   Data denormalization is reverse procedure, carried out purely for reasons of improving performance.It maybe efficient for a high-throughput system to replicate data for certain data. 

 

Question: What is the advantage of using PreparedStatement?   

Answer:   If we are using PreparedStatement the execution time will be less.The PreparedStatement object contains not just an SQL statement,but the SQL statement that has been precompiled.This means that when the PreparedStatement is executed,the RDBMS can just run the PreparedStatement's Sql statement without having to compile it first. 

 

Question: What is a "dirty read"?   

Answer:   Quite often in database processing, we come across the situation wherein one transaction can change a value, and a second transaction can read this value before the original change has been committed or rolled back. This is known as a dirty read scenario because there is always the possibility that the first transaction may rollback the change, resulting in the second transaction having read an invalid value. While you can easily command a database to disallow dirty reads, this usually degrades the performance of your application due to the increased locking overhead. Disallowing dirty reads also leads to decreased system concurrency. 

 

Question: What is Metadata and why should I use it?   

Answer:   Metadata ('data about data') is information about one of two things: Database information (java.sql.DatabaseMetaData), or Information about a specific ResultSet (java.sql.ResultSetMetaData).

Use DatabaseMetaData to find information about your database, such as its capabilities and structure. Use ResultSetMetaData to find information about the results of an SQL query, such as size and types of columns 

 

Question: Different types of Transaction Isolation Levels?   

Answer:   The isolation level describes the degree to which the data being updated is visible to other transactions. This is important when two transactions are trying to read the same row of a table. Imagine two transactions A & B.

Three types of inconsistencies can occur:

· Dirty-read: A has changed a row, but has not committed the changes. B reads the uncommitted data but his view of the data may be wrong if A rolls back his changes and updates his own changes to the database.

· Non-repeatable read: B performs a read, but A modifies or deletes that data later. If B reads the same row again, he will get different data.

· Phantoms: A does a query on a set of rows to perform an operation. B modifies the table such that a query of A would have given a different result. The table may be inconsistent.

TRANSACTION_READ_UNCOMMITTED : DIRTY READS, NON-REPEATABLE READ AND PHANTOMS CAN OCCUR.

TRANSACTION_READ_COMMITTED : DIRTY READS ARE PREVENTED, NON-REPEATABLE READ AND PHANTOMS CAN OCCUR.

TRANSACTION_REPEATABLE_READ : DIRTY READS , NON-REPEATABLE READ ARE PREVENTED AND PHANTOMS CAN OCCUR.

TRANSACTION_SERIALIZABLE : DIRTY READS, NON-REPEATABLE READ AND PHANTOMS ARE PREVENTED. 

 

Question: What is 2 phase commit?   

Answer:   A 2-phase commit is an algorithm used to ensure the integrity of a committing transactionIn Phase 1, the transaction coordinator contacts potential participants in the transaction. The participants all agree to make the results of the transaction permanent but do not do so immediately. The participants log information to disk to ensure they can complete Phase 2. If all the participants agree to commit, the coordinator logs that agreement and the outcome is decided. The recording of this agreement in the log ends Phase

In Phase 2, the coordinator informs each participant of the decision, and they permanently update their resources. 

 

Question: How do you handle your own transaction ?   

Answer:   Connection Object has a method called setAutocommit ( Boolean istrue)

- Default is true

Set the Parameter to false , and begin your transaction 

 

Question: What is the normal procedure followed by a java client to access the db.?   

Answer:   The database connection is created in 3 steps:

1.Find a proper database URL (see FAQ on JDBC URL)

2.Load the database driver

3.Ask the Java DriverManager class to open a connection to your database

In java code, the steps are realized in code as follows:

1.Create a properly formatted JDBR URL for your database. (See FAQ on JDBC URL for more information). A JDBC URL has the form

jdbc:someSubProtocol://myDatabaseServer/theDatabaseName 2. Class.forName("my.database.driver");

3 . Connection conn = DriverManager.getConnection("a.JDBC.URL", "databaseLogin","databasePassword"); 

 

Question: What is a data source?   

Answer:   A DataSource class brings another level of abstraction than directly using a connection object. Data source can be referenced by JNDI. Data Source may point to RDBMS, file System , any DBMS etc. 

 

Question: What are collection pools? What are the advantages?   

Answer:   A connection pool is a cache of database connections that is maintained in memory, so that the connections may be reused 

 

Question: How to call a Stored Procedure from JDBC?   

Answer:   The first step is to create a CallableStatement object. As with Statement an and PreparedStatement objects, this is done with an open Connection object. A CallableStatement object contains a call to a stored procedure.

E.g.

CallableStatement cs = con.prepareCall("{call SHOW_SUPPLIERS}");

ResultSet rs = cs.executeQuery(); 

 

 

Question: Why is XML such an important development?   

Answer:   It removes two constraints which were holding back Web developments:<br> 1. § dependence on a single, inflexible document type (HTML) which was being much abused for tasks it was never designed for;<br> 2. the complexity of full SGML, whose syntax allows many powerful but hard-to-program options.<br> § XML allows the flexible development of user-defined document types. It provides a robust, non-proprietary, persistent, and verifiable file format for the storage and transmission of text and data both on and off the Web; and it removes the more complex options of SGML, making it easier to program for. 

 

Question: What is the difference between URL instance and URLConnection instance?   (Networking)

Answer:   A URL instance represents the location of a resource, and a URLConnection instance represents a link for accessing or communicating with the resource at the location. 

 

Question: What are the two important TCP Socket classes?   (Networking)

Answer:   Socket and ServerSocket. ServerSocket is used for normal two-way socket communication. Socket class allows us to read and write through the sockets. getInputStream() and getOutputStream() are the two methods available in Socket class. 

 

Question: Can RMI and Corba based applications interact ?  

Answer:   Yes they can. RMI is available with IIOP as the transport protocol instead of JRMP. 

 

Question: How many types of protocol implementations does RMI have?  

Answer:   RMI has at least three protocol implementations: Java Remote Method Protocol(JRMP), Internet Inter ORB Protocol(IIOP), and Jini Extensible Remote Invocation(JERI). These are alternatives, not part of the same thing, All three are indeed layer 6 protocols for those who are still speaking OSI reference model. 

 

Question: Does RMI-IIOP support dynamic downloading of classes?  

Answer:   No, RMI-IIOP doesn't support dynamic downloading of the classes as it is done with CORBA in DII (Dynamic Interface Invocation).Actually RMI-IIOP combines the usability of Java Remote Method Invocation with the interoperability of the Internet Inter-ORB Protocol (IIOP).So in order to attain this interoperability between RMI and CORBA,some of the features that are supported by RMI but not CORBA and vice versa are eliminated from the RMI-IIOP specification. 

 


 Author & Copyright 2004: Thilip Kumar thilip@yahoo.com