学习Shark的一些理解

王朝other·作者佚名  2006-01-09
窄屏简体版  字體: |||超大  

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();

}

 
 
 
免责声明:本文为网络用户发布,其观点仅代表作者个人观点,与本站无关,本站仅提供信息存储服务。文中陈述内容未经本站证实,其真实性、完整性、及时性本站不作任何保证或承诺,请读者仅作参考,并请自行核实相关内容。
 
 
© 2005- 王朝網路 版權所有 導航