记得前段时间看到JavaScript部分关于for循环里面判断语句中,若出现对数组的个数判定时候,JavaScript里面的做法是先在循环体外定义一个变量将数组的个数赋值,然后for循环里面判断语句部分使用该变量,而不直接使用数组.length这种写法来提升性能————应该是这样
当时看到这里突然想到java里面这样的话也可以吧,只不过平常for循环里面直接使用arr.length/list.size()这样直接进行遍历操作。
闲来无事,做个测试,代码如下
public class PerformanceTest {
public static void main(String[] args) {
String[] strs = { "test0", "test1", "test2", "test3", "test4", "test5",
"test6", "test7", "test8", "test9",... };
System.out.println(strs.length);
long startT = System.currentTimeMillis();
for (int i = 0; i < strs.length; i++) {
System.out.print(strs[i]);
}
System.out.println("————————————————————————————");
long endT = System.currentTimeMillis();
System.out.println(endT - startT);
startT = System.currentTimeMillis();
for (int i = 0; i < 3000; i++) {
System.out.print(strs[i]);
}
System.out.println("————————————————————————————");
endT = System.currentTimeMillis();
System.out.println(endT - startT);
}
}
结果如下:
3000
test0test1test2test3test4test5test6test7...
11
test0test1test2test3test4test5test6test7...
6
一共3000个这样简单的数据组成的数组,两种方法输出结果可以看出结果差异还是挺大的。不过一方面数据简单,另一方面速度这么快可以忽略两者之间的差异了。项目中自己酌情考虑