1 2 3 4 下一页 1.缘起: 我们还是以多叉树IMultiTree章节介绍的那个例子来继续讲解。假设,在系统运行的过程中,集团又成立了分公司D及其下属的一些单位,这些资料已经被存入了数据库中,但是这些信息在我们当前正在运行的MultiTree实例中并不存在,如果此时向MultiTree实例请求与D分公司相关的信息,那么将一无所获。除非,你手动地将D分公司及其下属单位的节点值添加到MultiTree实例中。这是一个比较麻烦的动作。 试着设想一下这样一种情况,当我们要请求的节点在当前MultiTree实例中并不存在时,多叉树能自动地加载目标节点到MultiTree实例中,而且,如果需要的话,它会自动加载当前MultiTree实例中不存在的而目标节点又需要的其所有直接和间接的上级节点。比如,我们要向当前MultiTree实例请求D分公司下的部门M下的K小组,那么MultiTree会首先自动加载D分公司节点,再自动加载M部门节点,再自动加载K小组节点,然后返回K小组节点。 我设计了ESBasic.ObjectManagement.Trees. IAgileMultiTree来对IMultiTree进行扩展,以实现节点的自动加载。 为了完成自动加载,需要借助一个类似我们前面介绍的IObjectRetriever对象获取器的接口,这里叫做“节点获取器”IAgileNodePicker,正是它完成从存储设备提取节点值的任务的。 灵巧多叉树的形象示意图如下:
(责任编辑:admin) |