25.2. CSimple 和 Simple 之间的不同
简单语言是一种动态表达式语言,被运行时解析为一组 Camel Expressions 或 Predicates。
Csimple 语言被解析为常规 Java 源代码,并与所有其他源代码一起编译,或者在通过 camel-csimple-joor
模块 bootstrap 期间编译一次。
简单语言通常非常轻便且快,但对于一些通过 OGNL 路径进行动态方法调用的用例,则简单的语言执行运行时内省和反映调用。这对性能有开销,是创建简单原因的原因之一。
csimple 语言需要通过 OGNL 路径是 typesafe 和 method 调用,需要了解解析期间的类型。这意味着,对于 csimple 语言表达式,您需要在脚本中提供类类型,而简单的内省则在运行时是这个类。
换句话说,简单语言使用 duck typing (如果看起来像一个 duck )和 quacks (像 duck),那么它是一个 duck,而 csimple 则正在使用 Java 类型(类型安全)。如果有类型错误,则 simple 会在运行时报告此功能,而 csimple 会出现 Java 编译错误。
25.2.1. 额外的 CSimple 功能 复制链接链接已复制到粘贴板!
csimple 语言包括一些额外的函数,它们支持使用 Collection
, Map
或数组类型的一般用例。以下函数 bodyAsIndex、headerAsIndex 和 exchangePropertyAsIndex 用于这些用例,因为它们被输入。
功能 | 类型 | 描述 |
---|---|---|
bodyAsIndex(type, index) | 类型 |
为了用于从现有的 |
mandatoryBodyAsIndex(type, index) | 类型 |
为了用于从现有的 |
headerAsIndex (键,type,index) | 类型 |
为了用于从现有的 |
mandatoryHeaderAsIndex (key,type,index) | 类型 |
为了用于从现有的 |
exchangePropertyAsIndex(key, type, index) | 类型 |
为了用于从现有的 |
mandatoryExchangePropertyAsIndex(key, type, index) | 类型 |
为了用于从现有的 |
例如,给出以下简单表达式:
Hello $\{body[0].name}
Hello $\{body[0].name}
此脚本没有类型信息,简单语言将在运行时解决,方法是内省消息正文,如果基于集合,则查找第一个元素,然后通过反映调用名为 getName
的方法。
在 csimple (编译)中,我们希望预编译它,因此最终用户必须使用 bodyAsIndex 功能提供类型信息:
Hello $\{bodyAsIndex(com.foo.MyUser, 0).name}
Hello $\{bodyAsIndex(com.foo.MyUser, 0).name}