有一次我的项目中,要从用户指定的目录搜索指定的内容。可能是目录也可能是文件。而且用户要搜索的名称可能有特定的格式。并且能对所有子目录进行搜索。
对于特定格式的搜索,我们可以用正则表达式来做。例如,所有的*.ini为扩展名的文件名,其正则表达式为
.+\\.ini$
而对子目录的穷极搜索,可以使用在基本计算机课程就学过的递归函数。后面的程序中可以看到如何写。
为此设计了一个简单的搜索框架。搜索功能和搜索结果的处理是分开处理的。这也是为了达到最高的灵活性。其结构如下:
<pre>
+==========Class===============+
+ FileSearcher + +==========Interface=======+
+==============================+ + FileSearcherListener +
+ +search() + <>================o +==========================+
+ +registerSearcherListener() + + +found(File file) +
+ +unregisterSearcherListener()+ +==========================+
+==============================+
</pre>
通过上面的类结构图我们看到,完成搜索功能的是FileSearcher类,它提供search()方法来进行搜索。而 FileSearcherListener负责处理搜索到的项目。你可以通过实现FileSearcherListener接口来定制自己的搜索结果处理方式。并通过FileSearcher类的registerSearcherListener方法来注册你自己定义的处理处理类。这样的结构,很好的解决了搜索过程与搜索结果处理的强藕和问题。
这样我就可以很方便的定制我要搜索的内容并处理。来看看下面的示例:
<pre> /* 定义一个listener,来对进行处理,这个例子只是简单的在控制台打出文件名。*/
FileSearcherListener listener = new FileSearcherListener()
{
int count=1;
public void found(File file)
{
System.out.println("Found "+count+":"+file);
count++;
}
};
/* 构造FileSearcher类,指定搜索起始目录为c:/WINNT, 搜索类型为FILE, 匹配格式是所有*.ini文件。*/
FileSearcher search = new FileSearcher("c:/WINNT",FileSearcher.FILE,".+\\.ini$");
search.registerSearcherListener(listener);
search.search();
</pre>