Tuesday, September 28, 2010
Tuesday, September 21, 2010
Java Kicks Ruby on Rails in the Butt
Java Kicks Ruby on Rails in the Butt
— “What would you think if I told you that you can develop a web application at least ten times faster with Rails than you can with a typical Java framework?” Oops! Ten times faster! Well, after these comments I decided to learn Ruby on Rails. I need to know the true key of the productivity and programmer happiness.
Wednesday, September 8, 2010
Class member variable initialization
While declaring the class member variables we have to be very confident about the behavior of the member variables. For example some variable are constant and will be same across the class life cycle and some are instance variables which will be tightly bind with the object (instance) of the class.
When an instance of a class is created using new, initialization of the class's instance variables create for each unique instance.
Always use the static for the member variable which doesn’t change across the objects of the class.
public class TestClassVariable {
public TestClassVariable() {
// do nothing
}
public String country[] = { "
public static void main(String s[]) {
long start, end;
int[] a = new int[1000000];
start = System.currentTimeMillis();
for (int j = 0; j <>length; j++) {
TestClassVariable tstClassVar = new TestClassVariable();
}
end = System.currentTimeMillis();
System.out.println(end - start + " "
+ " milli seconds execution time");
}
}
Result: 94 milli seconds execution time
In the above code we used country as class instance variable and it takes 94MS but as we know country could be make as static member variable because it will be not going to change across the instances so the correct way to use as static member variable.
So we can change the program slightly and see the figures again
public class TestClassVariable {
public TestClassVariable() {
// do nothing
}
public static String country[] = { "
public static void main(String s[]) {
long start, end;
int[] a = new int[1000000];
start = System.currentTimeMillis();
for (int j = 0; j <>length; j++) {
TestClassVariable tstClassVar = new TestClassVariable();
}
end = System.currentTimeMillis();
System.out.println(end - start + " "
+ “milli seconds execution time");
}
}
Result: 16 milli seconds execution time
We could easily figure it out the performance get enhance 6 times then the original oneMonday, September 6, 2010
Calling object inside the loop
If any class having class member variable then class needs to be inside the loop and that will limit their scope which is good to garbage collect but if class used as Utility class and doesn’t have member class variable then we could declare the class out side of the loop and used inside the loop.
Below example shows there are only 32 ms would take to instantiate the object inside the loop but best thing is that it would limit the scope which is good during garbage collection
public class TestLoop {
public static void main(String s[]) {
long start, end;
int[] a = new int[1000000];
start = System.currentTimeMillis();
TestName tname1 = new TestName();
for (int i = 0; i <>
// tname1=new TestName();
}
end = System.currentTimeMillis();
System.out.println(end - start + " milli "
+ “seconds for One Time Loop");
start = System.currentTimeMillis();
for (int j = 0; j <>
TestName tname = new TestName();
}
end = System.currentTimeMillis();
System.out.println(end - start + " "
+ “milli seconds loop calling object inside Loop ");
}
}
Result: 0 milli seconds for One Time Loop
32 milli seconds for loop calling object inside Loop
As per above example you could see the declaring the object inside loop doesn’t have much impact on performance.
In below example explain the two ways to declare the object option 1 inside declaration and option 2 out side declaration.
Option 1:
for (int i=0; i
{
Object obj = tempList.get(i);
o. doOperation();
}
Option 2:
Object o;
for (int i=0; i
{
o = tempList.get(i);
o.doOperation();
}
We could say that Option1 better as it restricts scope of ‘obj’ variable to the for block. From a performance perspective, it might not have any effects in Java, but it might have in lower level compilers. They might put the variable in a register if you do the first.
Construction of an object using new is totally different from just declaring it, of course.
I think readability is more important than performance and from a readability standpoint, the first code is definitely better.
But if you have utility class which doesn’t have member variables we could instantiate once and reuse across the code.
In the below example I am trying to explain the utility class which could be instantiate once and use across the application.
import java.util.Calendar;
import java.util.Date;
public class TestLoop {
public static void main(String s[]) {
long start, end;
int[] a = new int[1000000];
Calendar cal = Calendar.getInstance();
start = System.currentTimeMillis();
for (int i = 0; i <>
Date dt = cal.getTime();
}
end = System.currentTimeMillis();
System.out.println(end - start + " milli "
+ "seconds for Instantiating object out side Loop");
start = System.currentTimeMillis();
TestName tname = null;
for (int j = 0; j <>
Date dt = Calendar.getInstance().getTime();
}
end = System.currentTimeMillis();
System.out.println(end - start + " "
+ "milli seconds Instantiating object inside Loop ");
}
}
0 milli seconds for Instantiating object out side Loop
797 milli seconds Instantiating object inside Loop