Fel是轻量级的高效的表达式计算引擎[Z]
Fel在源自于企业项目,设计目标是为了满足不断变化的功能需求和性能需求。
Fel是开放的,引擎执行中的多个模块都可以扩展或替换。Fel的执行主要是通过函数实现,运算符(+、-等都是Fel函数),所有这些函数都是可以替换的,扩展函数也非常简单。
Fel有双引擎,同时支持解释执行和编译执行。可以根据性能要求选择执行方式。编译执行就是将表达式编译成字节码(生成java代码和编译模块都是可以扩展和替换的)
Fel基于Java1.5开发,适用于Java1.5及以上版本。
表达式引擎:,欢迎交流。
Fel有多快?
通常情况下,Fel-0.7每秒可以执行千万次表达式(不包含编译时间)。速度是Jexl-2.0的20倍以上。
目前还没有发现开源的表达式引擎比Fel快。
具体的测试数据请参见http://code.google.com/p/fast-el/wiki/Performance。
为何要使用Fel?
Fel语法和API非常简单,语法与Java基本相同,几乎没有学习成本。
Fel非常快,上面已经做了简单说明。
Fel整个包只有300多KB。
Fel可以非常方便的访问数组、集合、Map的元素和对象的属性。
Fel可以非常方便的调用对象的方法和类方法(如果这些还不够,可以添加自定义函数)。
扩展Fel非常容易,扩展和修改Fel都非常简单。
Fel不能做什么?
Fel只支持表达式,不支持脚本。
Fel适用场景:
Fel适合处理海量数据,Fel良好的扩展性可以更好的帮助用户处理数据。
Fel同样适用于其他需要使用表达式引擎的地方(如果工作流、公式计算、数据有效性校验等等)
Fel使用例子:
1:算术表达式:
输出结果:67500
2:变量
使用变量,其代码如下所示:
输出结果:67500
3:访问对象属性
在Fel中,可能非常方便的访问对象属性,示例代码如下所示
4:访问数组、集合、Map
5:调用JAVA方法
输出结果:Everybody
6:自定义上下文环境
输出结果:天气:晴;温度:25
7:多层上下文环境(命名空间)
输出结果:
期望利润:50
实际利润:30
8:编译执行
执行结果:67500
备注:适合处理海量数据,编译执行的速度基本与Java字节码执行速度一样快。
9:自定义函数
执行结果:
hello fel hello fel
10:调用静态方法
如果你觉得上面的自定义函数也麻烦,Fel提供的$函数可以方便的调用工具类的方法 熟悉jQuery的朋友肯定知道”$”函数的威力。Fel东施效颦,也实现了一个”$”函数,其作用是获取class和创建对象。结合点操作符,可以轻易的调用工具类或对象的方法。
通过”$(‘class’).method“形式的语法,就可以调用任何等三方类包(commons lang等)及自定义工具类的方法,也可以创建对象,调用对象的方法。 未来版本的Fel会考虑直接注册java method。
发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/218677.html原文链接:https://javaforall.net
