public static void main(String[] args) {
Integer i = new Integer(3);
int REPEAT = 50000000;
Integer res;
long time = System.currentTimeMillis();
for (int j = REPEAT; j > 0; j--)
res = test1(i);
time = System.currentTimeMillis() - time;
System.out.println("test1(i) took " + time);
time = System.currentTimeMillis();
for (int j = REPEAT; j > 0; j--)
res = test2(i);
time = System.currentTimeMillis() - time;
System.out.println("test2(i) took " + time);
time = System.currentTimeMillis();
for (int j = REPEAT; j > 0; j--)
res = test3(i);
time = System.currentTimeMillis() - time;
System.out.println("test3(i) took " + time);
}
public static Integer test1(Object o) {
Integer i = (Integer) o;
return i;
}
public static Integer test2(Integer o) {
Integer i = (Integer) o;
return i;
}
public static Integer test3(int o) {
Integer i = (Integer) o;
return i;
}
输出结果:
test1(i) took 157
test2(i) took 47
test3(i) took 609
很明显在进行数据类型转换的时候会耗费一定的时间。