0

此方法使用递归来查找名称中包含特定字符串的文件。它在网络驱动器上搜索,有时必须搜索数百甚至数千个目录才能找到它要查找的内容。它相当慢——有时需要 5-10 秒。我怀疑延迟是由网络连接引起的,因为这个网络对于其他一切都非常快。无论如何,这只是我创造的东西,所以那里可能有更有效的东西。

public static File findFile(File root, String name)
{
    File [] dir = root.listFiles();
    File a = null;

    for(int i = 0; i < dir.length; i++)
    {
        if(dir[i].isDirectory() && a == null)
            a = findFile(dir[i],name);
        else if(dir[i].getName().indexOf(name) > -1)
            return dir[i];
    }

    return a;
}

那么有什么办法可以改善这一点吗?还是搜索这么多目录的过程总是那么慢?谢谢。

4

2 回答 2

1

这可能是矫枉过正,但考虑建立一个index

就个人而言,我过去曾使用Apache Lucene来索引各种 Web 资产,包括图像文件、PDF、html 等。使用 Lucene 4.1,添加到索引以及搜索索引非常简单。

将文件夹(和所有子文件夹)添加到索引

首先,将网络驱动器中的所有内容添加到索引中非常简单:

java org.apache.lucene.demo.IndexFiles -docs {path-to-folder}

搜索索引

将所有必需的文件添加到索引后,您可以使用 Lucene 库提供的搜索索引器来搜索文档:

IndexSearcher.search(query, n)

配置的可能性无穷无尽,您也不仅限于搜索文件名。

于 2013-01-23T21:06:46.683 回答
0

在大型目录结构中,搜索必须花费更长的时间。如果您需要速度,请考虑基于索引的方法(构建并动态更新文件名索引,并且只在其中进行查找)。

这正是 Linuxlocate命令的工作原理,它的搜索是即时的。

于 2013-01-23T20:57:43.130 回答