数据槽

概念" class="reference-link">数据槽 - 图3概念

在执行器执行流程时会分配唯一的一个数据槽给这个请求。不同请求的数据槽是完全隔离的。你可以理解为数据槽就是这个请求中的上下文,里面存放着此请求所有的数据。不同的组件之间是不传递参数的,所有的数据交互都是通过这个数据槽来实现的。

LiteFlow提供了一个默认的SLOT实现:DefaultSlot。这个默认的实现其实里面主要存储数据的容器就是一个Map。

比如可以通过getRequestData获得流程的初始参数,通过getChainName获取流程的命名,通过setInput,getInput,setOutput,getOutput设置和获取属于某个组件专有的数据对象。当然也提供了最通用的方法setDatagetData用来设置和获取业务的数据。

建议" class="reference-link">数据槽 - 图4建议

DefaultSlot虽然可以用,但是在实际业务中,用这个会存在大量的弱类型,存取数据的时候都要进行强转,颇为不方便。所以官方建议你自己去实现自己的SLOT。

自己只需要定义一个简单的值对象就可以,继承AbsSlot就可以了。自己定义的SLOT因为是强类型,更加贴合业务。

在LiteFlow的配置中,提供一个slotSize的参数可以去配置初始化数量,但是这个默认值就是1024,在2.6.0版本中,当slot容量不够时,会按照0.75的因子去进行自动扩容。所以这个值不推荐主动配置。除非有特殊情况。