学习Shark的一些理解
微生俊
2023-12-01
1、关于其API的存放路径问题,为什么不是在一个整体的src目录下,而是分了很多单独的目录
现在看是,为了将这些数量巨大的API分门别类的存放,以指示使用者在何种场合使用哪一部分API,比如api目录中为用户提供可编程的interface,corba中提供corba相关的服务。
2、关于Shark中Adapter模式的频繁使用问题
在Shark的设计思想中,我理解是基于一个Meta-Data Framework的框架,就是概念模型,而在实现的时候有一些与概念模型不完全相同的东西,所以作者就分别写了概念模型,与实现模型,然后用Adapter模式将这两个部分粘合起来,这就是在Shark模型中充斥着大量的XxxxImpl类,XxxxWraper类的原因。(具体内容请参见我的另外一个文章Shark的概念模型与实现模型)
3、如何使用API的方式来调用Shark引擎
首先需要将Shark的lib下所有jar都引入到本project的Classpath中(好像原包中缺少hibernate包,可以下载对应的),
然后在modules目录中进行搜索src,这样就可以将每一个单独目录中的源文件合在一起,拷贝所有搜索结果到一个目录src,引入到jb或eclipse中,编译,就可以比较方便的看到Shark的源码了。
主要使用org.enhydra.shark.api.client包。
①:Shark.configure(),一般需要指定其shark.conf的位置,该文件主要为SharkEngineManager的提供各种管理器的配置,你可以扩展shark的框架,用自己的Manager类来实现特殊的功能,完成后写在shark.conf配置文件中。
②:Shark.getInstance(),返回一个SharkInterface的实例
此后,你需要决定是获得一个与Shark服务器的连接执行分配的任务(需要服务器运行),还是获得一个AdminInterface来管理用户、组、Package(不需要服务器运行)。
比如,查看一个用户有几个代办项目的实现代码:
Shark.configure("Shark.conf");
SharkInterface si = Shark.getInstance();
SharkConnection sc = si.getSharkConnection();
try {
sc.connect("leo", "l", "Shark", "");
System.out.println("你有" + sc.getResourceObject().how_many_work_item() + "个任务");
} catch (Exception e) {
e.printStackTrace();
}