有一次我的项目中,要从用户指定的目录搜索指定的内容。可能是目录也可能是文件。而且用户要搜索的名称可能有特定的格式。并且能对所有子目录进行搜索。
对于特定格式的搜索,我们可以用正则表达式来做。例如,所有的*.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>