标签:
昨天下午修复了系统的bug(这个bug竟然能占非常高的资源,而且会影响到系统的核心服务。。。),就是下面的这两段代码,造成的bug。(不过这个bug仅存在于Ubuntu共享目录下,在非共享目录和window系统中均不会出现这个bug),
for (int i = 0; i < picIpDir.list().length; i++) //循环五六个photo要1s(文件量大)
{
log.info(i);
String fileName = picIpDir.list()[i];
if ((fileName.indexOf("SnapshotSubface") > 0) && (isBetween(fileName, requestImage.startTime, requestImage.endTime))) {
File readfile = new File(picIpDir.getAbsolutePath() + File.separator + fileName);
String imageContect = getImageBase64(readfile.getAbsolutePath());
if (imageContect != null) {
rtnList.add(imageContect);
}
}
}
return rtnList;
}
最终改为:
for (String fileName:picIpDir.list()) //这样读取就正常了.
{
if ((fileName.indexOf("SnapshotSubface") > 0) && (isBetween(fileName, requestImage.startTime, requestImage.endTime))) {
File readfile = new File(picIpDir.getAbsolutePath() + File.separator + fileName);
String imageContect = getImageBase64(readfile.getAbsolutePath());
if (imageContect != null) {
rtnList.add(imageContect);
}
}
}
return rtnList;
}
自我感觉,可能是Ubuntu下计算文件夹下文件数组的长度花费了资源(Ubuntu共享目录是通过路由的方式,共享windows文件夹到Ubuntu下面的。)
然后对java的for循环进行了学习也就明白了for循环的具体用法调优,参考博文:http://www.360doc.com/content/11/0527/11/987036_119734904.shtml
package stytle;
import java.util.ArrayList;
import java.util.Iterator;
import java.util.List;
/**
* @author buru
* @date 2009年11月29日15:04:04
* @qq 258274473
* @email shaliebao@163.com
* */
public class ForLoop {
/**
* just for test
*
* @param args
*/
public static void main(String[] args) {
List<String> list = new ArrayList<String>();
list.add("sha");
list.add("lie");
list.add("bao");
/**
* 方法一:最普通的不加思考的写法
* <p>
* 优点:较常见,易于理解
* <p>
* 缺点:每次都要计算list.size()
*/
for (int i = 0; i < list.size(); i++) {
System.out.println(list.get(i));
}
/**
* 方法二:数组长度提取出来
* <p>
* 优点:不必每次都计算
* <p>
* 缺点:1、m的作用域不够小,违反了最小作用域原则 2、不能在for循环中操作list的大小,比如除去或新加一个元素
*/
int m = list.size();
for (int i = 0; i < m; i++) {
System.out.println(list.get(i));
}
/**
* 方法三:数组长度提取出来
* <p>
* 优点:1、不必每次都计算 2、所有变量的作用域都遵循了最小范围原则
* <p>
* 缺点:1、m的作用域不够小,违反了最小作用域原则 2、不能在for循环中操作list的大小,比如除去或新加一个元素
*/
for (int i = 0, n = list.size(); i < n; i++) {
System.out.println(list.get(i));
}
/**
* 方法四:采用倒序的写法
* <p>
* 优点:1、不必每次都计算 2、所有变量的作用域都遵循了最小范围原则
* <p>
* 缺点:1、结果的顺序会反 2、看起来不习惯,不易读懂
* <p>
* 适用场合:与显示结果顺序无关的地方:比如保存之前数据的校验
*/
for (int i = list.size() - 1; i >= 0; i--) {
System.out.println(list.get(i));
}
/**
* 方法五:Iterator遍历
* <p>
* 优点:简洁
* <p>
* 缺点:
*/
for (Iterator<String> it = list.iterator(); it.hasNext();) {
System.out.println(it.next());
}
/**
* 方法六:jdk1.5新写法
* <p>
* 优点:简洁结合泛型使用更简洁
* <p>
* 缺点:jdk1.4向下不兼容
*/
for (Object o : list) {
System.out.println(o);
}
}
}
此外不要在for循环内部声明变量
如
bad:
for(;;){
Object obj = new Object();
}
good:
Object obj=null;
for(;;){
obj = new Object();
}java File获取Ubuntu共享目录 for循环遍历速度
标签:
原文地址:http://my.oschina.net/u/2330859/blog/470597