- Java manipulates objects by reference, and all object variables are references. However, Java doesn't pass method arguments by reference; it passes them by value.
- Java is strictly pass-by-value, exactly as in C.
- Java has pointers and is strictly pass-by-value.
Friday, April 30, 2010
Java pass by value or pass by reference
Thursday, April 29, 2010
Encapsulation in JAVA
Encapsulation in java means declare instance variables of class as private and access that instance variables using public methods.
Following is the example which shows that Person class having name and age are private instance variables and those are accessed by public getter and setter methods.
public class Person {
private String name;
private int age;
public String getName() {
return name;
}
public void setName(String name) {
this.name = name;
}
public int getAge() {
return age;
}
public void setAge(int age) {
this.age = age;
}
}
Following is the example which shows that Person class having name and age are private instance variables and those are accessed by public getter and setter methods.
public class Person {
private String name;
private int age;
public String getName() {
return name;
}
public void setName(String name) {
this.name = name;
}
public int getAge() {
return age;
}
public void setAge(int age) {
this.age = age;
}
}
OOPs concepts in JAVA
- Abstraction: Hides certain details and only show the essential features of the object.
- Encapsulation: The internal representation of an object is generally hidden from view outside of the object's definition.
- Inheritance: Defines relationships among classes in an object-oriented language.
- Polymorphism: Define more than one method with the same name.
finally block not executed
Finally block is always executed except some of the following cases.
- If the JVM exits while the
try
orcatch
code is being executed, then thefinally
block may not execute.
- If the thread executing the
try
orcatch
code is interrupted or killed, thefinally
block may not execute even though the application as a whole continues.
J2EE Design Patterns
- Business Delegate
- Composite Entity
- Composite View
- Data Access Object (DAO)
- Fast Lane Reader
- Front Controller
- Intercepting Filter
- Model-View-Controller
- Service Locator
- Session Facade
- Transfer Object
- Value List Handler
- View Helper
Tuesday, April 20, 2010
Static vs Transient variables
Static variables
static int testVariable;
. . .
}
Transient variables
transient int testVariable;
. . .
}
- Static variables are class variables.
- Static variables can be serialized.
- static modifier applies to static variables.
static int testVariable;
. . .
}
Transient variables
- Transient variables are member or instance variables of class.
- Transient variables can not be serialized.
- transient modifier applies to transient variables.
transient int testVariable;
. . .
}
Thursday, April 15, 2010
JDK 5 Enhancements in Java Language
1. Generics - This is an enhancement to the type system allows a type or method to operate on objects of various types while providing compile-time type safety. It adds compile-time type safety to the Collections Framework and eliminates the drudgery of casting.
e.g.
Previously
Array List numbers = new ArrayList();
Now in JDK 5.0
Array List<Integer> numbers = new ArrayList<Integer> ();
2. Enhanced for Loop - This new language construct eliminates the drudgery and error-proneness of iterators and index variables when iterating over collections and arrays.
e.g.
Previously
Iterator itr = numbers.iterator();
while
(itr.hasNext())
{
Integer element = (Integer)itr.next();
System.out.println (number);}
Now in JDK 5.0
for (Integer number: numbers)
{
System.out.println (number);
}
3. Autoboxing/Unboxing - This facility eliminates the drudgery of manual conversion between primitive types (such as int, long) and wrapper types (such as Integer, Long).
e.g.
int number = 1;
Previously
Integer number2 = (Integer) number;
Now in JDK 5.0
Integer number2 = number;
4. Typesafe Enums - This flexible object-oriented enumerated type facility allows you to create enumerated types with arbitrary methods and fields. It provides all the benefits of the Typesafe Enum pattern ("Effective Java," Item 21) without the verbosity and the error-proneness.
e.g.
Previously
public static final int SEASON_WINTER = 0;
public static final int SEASON_SPRING = 1;
public static final int SEASON_SUMMER = 2;
public static final int SEASON_FALL = 3;
Now in JDK 5.0
enum Season {WINTER, SPRING, SUMMER, FALL}
5. Varargs - This facility eliminates the need for manually boxing up argument lists into an array when invoking methods that accept variable-length argument lists.
e.g.
Previously
Object[] arguments = {
new Integer(7),
new Date(),
"a disturbance in the Force"
};
String result = MessageFormat.forma("At {1,time} on {1,date}, there was {2} on planet "
+ "{0,number,integer}.", arguments);
Now in JDK 5.0
Using Varargs no need to create object array separately, we can give arguments directy.
String result = MessageFormat.format("At {1,time} on {1,date}, there was {2} on planet "
+ "{0,number,integer}.",
7, new Date(), "a disturbance in the Force");
6. Static Import - This facility lets you avoid qualifying static members with class names without the shortcomings of the "Constant Interface antipattern."
e.g.
Previously
double r = Math.cos(Math.PI * theta);
Now in JDK 5.0
import static java.lang.Math.*;
Once the static members have been imported, they may be used without qualification or class names:
double r = cos(PI * theta);
7. Annotations (Metadata) - This language feature lets you avoid writing boilerplate code under many circumstances by enabling tools to generate it from annotations in the source code. This leads to a "declarative" programming style where the programmer says what should be done and tools emit the code to do it. Also it eliminates the need for maintaining "side files" that must be kept up to date with changes in source files. Instead the information can be maintained in the source file.
Now in JDK 5.0
public @ interface Test{}
Wednesday, April 14, 2010
Retrieve key from HashMap using value
Below is the code to retrieve the key from HashMap using value
import java.util.HashMap;
import java.util.Map;
import java.util.Set;
import java.util.Map.Entry;
public class TestClass {
public static void main(String[] args) {
Map<Integer, Person> people = new HashMap<Integer, Person>();
Person person1 = new Person();
person1.setName("Mack");
person1.setPost("Dev");
Person person2 = new Person();
person2.setName("John");
person2.setPost("Dev");
people.put(1, person1);
people.put(2, person2);
Set<Entry<Integer, Person>> peopleSet = people.entrySet();
for (Entry<Integer, Person> entry : peopleSet) {
Integer key = entry.getKey();
Person value = entry.getValue();
if (value.equals(person2)) {
System.out.println("Key = " + key);
}
}
}
}
import java.util.HashMap;
import java.util.Map;
import java.util.Set;
import java.util.Map.Entry;
public class TestClass {
public static void main(String[] args) {
Map<Integer, Person> people = new HashMap<Integer, Person>();
Person person1 = new Person();
person1.setName("Mack");
person1.setPost("Dev");
Person person2 = new Person();
person2.setName("John");
person2.setPost("Dev");
people.put(1, person1);
people.put(2, person2);
Set<Entry<Integer, Person>> peopleSet = people.entrySet();
for (Entry<Integer, Person> entry : peopleSet) {
Integer key = entry.getKey();
Person value = entry.getValue();
if (value.equals(person2)) {
System.out.println("Key = " + key);
}
}
}
}
Tuesday, April 13, 2010
Servlet Chaining
Servlet Chaining means the output of one servlet given as a input to another servlet. Servlet Aliasing allows us to invoke more than one servlet in sequence when the URL is opened with a common servlet alias. The output from first Servlet is sent as input to other Servlet and so on. The Output from the last Servlet is sent back to the browser. The entire process is called Servlet Chaining.
How to do Servlet Chaining in Servlet Programming?
Using include
RequestDispatcher rd = req.getRequestDispatcher("SecondServlet");
Using forward
How to do Servlet Chaining in Servlet Programming?
Using include
RequestDispatcher rd = req.getRequestDispatcher("SecondServlet");
rd.include(request, response);
Using forward
RequestDispatcher rd = req.getRequestDispatcher("SecondServlet");
rd.
forward(request, response);
Monday, April 12, 2010
JDBC driver types
JDBC drivers are divided into four types.
- Type 1: JDBC-ODBC Bridge
- Type 2: Native-API/partly Java driver
- Type 3: Net-protocol/all-Java driver
- Type 4: Native-protocol/all-Java driver
Java Database Connectivity (JDBC)
JDBC is Java Database Connectivity helps to write java applications using databases.
Steps to use JDBC in java applications as follows
Class.forName("driveClassName");
Connection con = DriverManager.getConnection(
"jdbc:driveName:databaseName", "login", "password");
Statement stmt = con.createStatement();
ResultSet rs = stmt.executeQuery("SELECT * FROM Table");
while (rs.next()) {
int a = rs.getInt("column1");
String b = rs.getString("column2");
float c = rs.getFloat("column3");
}
} catch (SQLException e) {
e.printStackTrace();
} catch (ClassNotFoundException e) {
e.printStackTrace();
} finally {
// close the connection
}
Steps to use JDBC in java applications as follows
- Load the JDBC driver.
- Define the connection URL.
- Establish the connection.
- Create a statement object.
- Execute a query or update.
- Process the results.
- Close the connection.
Class.forName("driveClassName");
Connection con = DriverManager.getConnection(
"jdbc:driveName:databaseName", "login", "password");
Statement stmt = con.createStatement();
ResultSet rs = stmt.executeQuery("SELECT * FROM Table");
while (rs.next()) {
int a = rs.getInt("column1");
String b = rs.getString("column2");
float c = rs.getFloat("column3");
}
} catch (SQLException e) {
e.printStackTrace();
} catch (ClassNotFoundException e) {
e.printStackTrace();
} finally {
// close the connection
}
Serialization and Deserialization
- Serialization is the process of transforming an in-memory object to a byte stream.
- An object is serialized by writing it to an ObjectOutputStream.
- Serialization Code
ObjectOutputStream oos = new ObjectOutputStream( out );
oos.writeObject(new String ());
oos.close ();
- Deserialization is the inverse process of reconstructing an object from a byte stream to the same state in which the object was previously serialized.
- An object is deserialized by reading it from an ObjectInputStream.
- Deserialization Code
FileInputStream in = new FileInputStream( "test.txt" );
ObjectInputStream ois = new ObjectInputStream( in );
String s = (String) ois.readObject();
ois.close();
JAR WAR and EAR Files
JAR Files (Java Archive):
- These files are with the .jar extension.
- The .jar files contain the classes, libraries, resources and accessories files like property files.
WAR Files (Web Archive):
- These files are with the .war extension.
- The war file contains JSP, html, JavaScript and other files for necessary for the development of web applications.
- The war file contains the web application that can be deployed on the any servlet/jsp container.
EAR Files:
- These files are with the .ear extension.
- The .ear file contains the EJB modules of the applications.
- The ear file contains the ejb application that can be deployed on the any application server with ejb container.
Difference between customTags and JavaBeans
- JavaBeans are the data handlers of JSP and aid in encapsulating data management logic. They are used for storage Tags on the other hand, aid computational logic related to a particular request.
- Tags are thread safe; beans are not. Beans like other separate utility classes, have to be made thread safe by the developers.
- Tags are aware of the environment (the page context) in which they execute. Beans are not.
- Tags remain in the translation unit.We can think of tags as events occuring in the execution of a JSP page. Beans are object stores that reside outside the translation unit.
- Tags can access implicit objects. Beans are cannot.
- Tags only have page scope. They are created and destroyed withen a single request and in a single page. They can access other objects in all the scopes, though. Beans, on the other hand. Are themselves objects that reside in different scopes. Therefore, tags can access and manipulte beans, while beans do not access and manipulate tags.
- The Tag Extension API designed closely with the concept of a JSP page in mind. They may not be used in other applications. Beans, on the other hand are supposed to be resuable compnents and can be used by other container.
- Tags are not persistent objects. Beans have properties, and properties have values. A set of values is called the state of the bean. This state can be persisted via serialization and resued later.
Sunday, April 11, 2010
JSP Standard Actions
JSP standard actions are commands given to the JSP engine. They direct the engine to perform certain tasks during the execution of a page.
e.g. The following line instructs the engine to forward request to another JSP page, welcome.jsp from current JSP page.
<jsp:forward page="welcome.jsp"/>
There are six standard JSP actions:
e.g. The following line instructs the engine to forward request to another JSP page, welcome.jsp from current JSP page.
<jsp:forward page="welcome.jsp"/>
There are six standard JSP actions:
- jsp:include
- jsp:forward
- jsp:useBean
- jsp:setProperty
- jsp:getProperty
- jsp:plugin
Saturday, April 10, 2010
Difference between GET Method and POST Method
GET Method
- Target resource type is Active or passive
- Type of data is Text
- The amount of data handled by GET Method is not more than 255 characters.
- Data is part of the URL and is visible to the user in the URL field of browser.
- Data can be cached in the browser's URL History.
- Target resource type is Active
- Type of data is Text as well as Binary
- The amount of data handled by POST Method is unlimited.
- Data is not a part of the URL and is sent as the request message body. It is not visible to the user in the URL field of browser.
- Data is not cached in the browser's URL History.
Thursday, April 8, 2010
Difference between abstract class and interface
What is an Abstract Class?
- An abstract class is a special kind of class that cannot be instantiated.So the question is why we need a class that cannot be instantiated? An abstract class is only to be sub-classed (inherited from). In other words, it only allows other classes to inherit from it but cannot be instantiated. The advantage is that it enforces certain hierarchies for all the subclasses. In simple words, it is a kind of contract that forces all the subclasses to carry on the same hierarchies or standards.
- A class may inherit only one abstract class.
- An abstract class can contain access modifiers for the subs, functions, properties
- Fast
- An abstract class can have fields and constants defined
What is an Interface?
- An interface is not a class. It is an entity that is defined by the word Interface. An interface has no implementation; it only has the signature or in other words, just the definition of the methods without the body. As one of the similarities to Abstract class, it is a contract that is used to define hierarchies for all subclasses or it defines specific set of methods and their arguments. The main difference between them is that a class can implement more than one interface but can only inherit from one abstract class.
- A class may inherit several interfaces.
- An interface cannot have access modifiers for the subs, functions, properties etc everything is assumed as public
- Requires more time to find the actual method in the corresponding classes.
- No fields can be defined in interfaces
Subscribe to:
Posts (Atom)