我们都经常使用一些循环耗时计算的操作,特别是for循环,它是一种重复计算的操作,如果处理不好,耗时就比较大,如果处理书写得当将大大提高效率,下面总结几条for循环的常见优化方式。
首先,我们初始化一个集合 list,如下:
List<String>list=newArrayList<String>();
方法一:最常规的不加思考的写法
for(inti=0;i<list.size();i++){
System.out.println(list.get(i));
}
优点:较常见,易于理解
缺点:每次都要计算list.size()
方法二:数组长度提取出来
intm=list.size();
for(inti=0;i<m;i++){
System.out.println(list.get(i));
}
优点:不必每次都计算
缺点:1. m的作用域不够小,违反了最小作用域原则
不能在for循环中操作list的大小,比如除去或新加一个元素
方法三:数组长度提取出来
for(inti=0,n=list.size();i<n;i++){
System.out.println(list.get(i));
}
优点:不必每次都计算 ,变量的作用域遵循最小范围原则
缺点:1. m的作用域不够小,违反了最小作用域原则
2.不能在for循环中操作list的大小,比如除去或新加一个元素
方法四:采用倒序的写法
for(inti=list.size()-1;i>=0;i--){
System.out.println(list.get(i));
}
优点:不必每次都计算 ,变量的作用域遵循最小范围原则缺点:1、结果的顺序会反 2、看起来不习惯,不易读懂适用场合:与显示结果顺序无关的地方:比如保存之前数据的校验
方法五:Iterator 遍历
for(Iterator<String>it=list.iterator();it.hasNext();){
System.out.println(it.next());
}
优点:简洁
方法六:jdk1.5后的写法
for(Objecto:list){
System.out.println(o);
}
优点:简洁结合泛型使用更简洁
缺点:jdk1.4向下不兼容
方法七:循环嵌套外小内大原则
for(inti=0;i<10;i++){
for(intj=0;j<10000;j++){
}
}
原因
方法八:循环嵌套提取不需要循环的逻辑
//前:
inta=10,b=11;
for(inti=0;i<10;i++){
i=i*a*b;
}
//后:
intc=a*b;
for(inti=0;i<10;i++){
i=i*c;
}
方法九:异常处理写在循环外面
反例
for(inti=0;i<10;i++){
try{
}catch(Exceptione){
}
}
正例
try{
for(inti=0;i<10;i++){
}
}catch(Exceptione){
}