第一次运行耗时为什么比较久?

落叶似秋 2016-04-04 01:49:35
同样的代码。

package 遍历文件夹;

import java.io.*;
import java.util.*;

class Tool
{
/*
*递归遍历文件夹
*@path 路径
*@type 按文件类型过滤
*/
static List<File> list =new LinkedList<File>();
public static List<File> getFiles1(String path, String type)
{

File file=new File(path);
File[] fs=file.listFiles();
for (File f:fs)
{
if (f.isFile())
{
if ((f.getName().toLowerCase()).endsWith(type))
list.add(f);
}
else
{
getFiles1(f.getAbsolutePath(), type);
}
}
return list;

}

/*
*非递归遍历文件夹
* @path 路径
* @type 按文件类型过滤
*/
public static List<File> getFiles2(String path, String type)
{
// TODO: Implement this method
List<File> files=new LinkedList<File>();
LinkedList<File> stack=new LinkedList<File>();
File file=new File(path);
for (File f:file.listFiles())
{
if (f.isFile())
{
if ((f.getName().toLowerCase()).endsWith(type))
files.add(f);
}
else
{
stack.push(f);
}

}
//不为空则继续循环
while (stack.size() != 0)
{
file = stack.pop();
for (File f:file.listFiles())
{
if (f.isFile())
{
if ((f.getName().toLowerCase()).endsWith(type))
files.add(f);
}
else
stack.push(f);
}
}
return files;
}
}

public class Main
{

public static void main(String[] args)
{

final String path="D:\\Users\\Administrator";
System.out.println(">>>遍历:" + path);
long time=System.currentTimeMillis();
List<File> fs1=Tool.getFiles1(path, "");
System.out.println("文件数量:" + fs1.size());
System.out.println("递归耗时:" + (double)(System.currentTimeMillis() - time)/1000+"s");

System.out.println();

time = System.currentTimeMillis();
List<File> fs2=Tool.getFiles2(path, "");
System.out.println("文件数量:" + fs2.size());
System.out.println("非递归耗时:" + (double)(System.currentTimeMillis() - time)/1000+"s");


}


}

这是第一次运行时的耗时:

这是非第一次的运行耗时:

为什么后面的耗时比前面的耗时少了那么多?求解。谢谢了
...全文
297 4 打赏 收藏 转发到动态 举报
AI 作业
写回复
用AI写文章
4 条回复
切换为时间正序
请发表友善的回复…
发表回复
家里敷泥呀 2016-04-05
  • 打赏
  • 举报
回复
引用 3 楼 e_one 的回复:
引用 2 楼 Q80470101 的回复:
我猜想和系统本身的索引机制有关
谢谢,能说的详细一些吗,没学过操作系统相关知识
只是猜想,这方面我也没有太多经验
落叶似秋 2016-04-04
  • 打赏
  • 举报
回复
引用 2 楼 Q80470101 的回复:
我猜想和系统本身的索引机制有关
谢谢,能说的详细一些吗,没学过操作系统相关知识
家里敷泥呀 2016-04-04
  • 打赏
  • 举报
回复
我猜想和系统本身的索引机制有关
家里敷泥呀 2016-04-04
  • 打赏
  • 举报
回复
这是个有趣的问题

62,635

社区成员

发帖
与我相关
我的任务
社区描述
Java 2 Standard Edition
社区管理员
  • Java SE
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告
暂无公告

试试用AI创作助手写篇文章吧