Maven引用坐标:
org.tinygroup
vfs
0.0.12
一开始,本人抱着对Apache的绝对信任,选择了Apache VFS来进行文件访问的封装,确实,他的API是统一的、优雅的,支持的协议种类也非常多,在简单了解之后,觉得就用它吧,总不能什么轮子都自己造。
于是Apache VFS就进入了我的框架,功能也完全良好。但是在压力测试的时候,忽然发现有内存泄露问题,dump一下内存,进行分析之后,发现原来是Apache VFS 2.0惹得祸,看一看apache VFS已经好久没有升级了,跟踪了一下源码,发现有些地方,比较诡异,就是有时候进有时候不进,查之良久而不得,只好下决定把Apache VFS从里面拿掉,而拿掉之前,就需要有同样功能的东东支撑,不得已,花费2天时间写了一个VFS,功能比Apache的VFS少一些,但是够用了。然后花了一天时间,把原来Apache VFS的代码迁移到新的VFS之上,做此项迁移工作的小弟手指都木了,迁移完之后,再行测试,内存泄露问题不再存在。
好了,上面讲了前因,下面就介绍一下VFS的构成及实现:
模式提供者接口用于扩展各种文件来源,比如:本地文件,HTTP文件,FTP文件,Jar包文件,Zip文件等等,其接口声明如下:
/**
* 模式提供者接口
*/
public interface SchemaProvider {
/**
* 是否匹配
*
* @param resource
* @return 如果返回true,表示此提供者可以处理,返回false表示不能处理
*/
boolean isMatch(String resource);
/**
* 返回处理的模式
*
* @return
*/
String getSchema();
/**
* 解析资源,并返回文件对象
*
* @param resource
* @return
*/
FileObject resolver(String resource);
}
文件对象FileObject,是对文件的访问的统一接口,它的定义如下:
public interface FileObject {
String getFileName();// 返回文件名
String getPath();// 返回路径
String getAbsolutePath();// 返回绝对路径
String getExtName();// 返回扩展名