最近用到了for的嵌套循环,以前总是觉得这种方式很耗性能,没有去用它,最近我遇到了一个问题,不知道怎么解决,就用了嵌套,可又担心其性能,网上找找资料看到了这个性能测试,我把它放到这里,大家也可以参照下,一测试就知道那种嵌套更加优化点了。
[b]测试结果:[/b]
5171
2849
552
557
package com.line;
public class TestForLoop {
public static void main(String[] args) {
int small = 1;
int middle = 1000;
int large = 1000000;
// 大循环在外面,小循环在里面,变量每次生成
long t = System.currentTimeMillis();
for (int i = 1; i <= large; i++) {
for (int j = 1; j <= middle; j++) {
for (int k = 1; k <= small; k++) {
}
}
}
System.out.println(System.currentTimeMillis() - t);
// 大循环在外面,小循环在里面,变量统一生成
t = System.currentTimeMillis();
int i, j, k;
for (i = 1; i <= large; i++) {
for (j = 1; j <= middle; j++) {
for (k = 1; k <= small; k++) {
}
}
}
System.out.println(System.currentTimeMillis() - t);
// 小循环在外面,大循环在里面,变量每次生成
t = System.currentTimeMillis();
for (int kk = 1; kk <= small; kk++) {
for (int jj = 1; jj <= middle; jj++) {
for (int ii = 1; ii <= large; ii++) {
}
}
}
System.out.println(System.currentTimeMillis() - t);
// 小循环在外面,大循环在里面,变量统一生成
t = System.currentTimeMillis();
int ii, jj, kk;
for (kk = 1; kk <= small; kk++) {
for (jj = 1; jj <= middle; jj++) {
for (ii = 1; ii <= large; ii++) {
}
}
}
System.out.println(System.currentTimeMillis() - t);
}
}
[b]测试结果:[/b]
5171
2849
552
557