从Camel中学习FluntApi设计
一、 流式的好处
- 更接近与自然语言;
- 操作连贯,一行搞定(如Builder);
二、 设计原则
1. Flunt Api在程序设计时,不能完全根据类的方法来限制其层级。
例如,Branch在自然语言上,其后面只能跟when和otherwise。但是程序设计时,出于Java语言的特性,类的继承等原因并不能完全限制,Branch类可能继承了父类的方法。
1)自然语言:
1 | Branch --> when / otherwise |
2)编程语言:
1 | interface ContainerDefinition { |
2. 设计方法时注意方法的访问级别
1)public方法用于客户端流式API调用的接口,尽量贴近自然语言;
2)protect方法用于语句中可向子语句传递的内部方法,不会暴露给客户端;
3)private方法用于本语句的逻辑实现,不会被其他任何语句调用;
三、设计方法
1. 找出同级别语句,整理为结构图;如下为EDI的数据转化的Flunt Api设计:
1 | Dt Root |
2. 根据级别分组,不同分组是隔离的;
1)第一层分组:
1 | Loop,Branch,Try |
2)第二层分组
1 | 1)Break; |
3. 分析第一层分组的语句,他们之间是可以任意顺序连接的,故设计根类的方法如下:
1 | class DtRoot { |
4. 分析第二层分组,其隶属于第一层分组的某个语句,称为父语句;
父语句的方法有两种设计,如下:
1)返回第一层的语句;
1 | class Branch { |
2)返回第二层语句;
1 | class BranchDefinition extend ContainerDefinition { |
四、EDI的实现
1. 限定流程的Core,第三方只能扩展Processor(目前Processor含set,attr,validator等processor)。
2. 非完全意义上的流式实现,去掉了end这类返回父语句的操作,如下所示:
1)正常流式
1 | branch.when(expr).process(processorA).otherwise().process(processorB).endbranch() |
2)edi实现
1 | branch.when(expr).process(processorA); |
五、附录
