Apache Camel(在JavaDSL)中是否有类似于Java开关盒的构造?
例如:
from( incomingRoute )
.choice()
.when( simple( "${body.getType} == '" + TYPE.A.name() + "'" ) )
.to( A_Endpoint )
.when( simple( "${body.getType} == '" + TYPE.B.name() + "'" ) )
.to( B_Endpoint )
.when( simple( "${body.getType} == '" + TYPE.C.name() + "'" ) )
.to( C_Endpoint )
.otherwise()
.to( errorEndpoint );
可以翻译成更类似于switch的东西吗?我的意思是,我不想使用简单的谓词,只使用body元素类型的值。还是我的方法完全错了?(这可能是合理的)
我通常更喜欢在特定场景中使用Java 8 Lambda:
public void configure() throws Exception {
from( incomingRoute )
.choice()
.when( bodyTypeIs( TYPE.A ) )
.to( A_Endpoint )
.when( bodyTypeIs( TYPE.B ) )
.to( B_Endpoint )
.when( bodyTypeIs( TYPE.C ) )
.to( C_Endpoint )
.otherwise()
.to( errorEndpoint );
}
private Predicate bodyTypeIs(TYPE type) {
return e -> e.getIn().getBody(BodyType.class).getType() == type;
}
此外,将Camel的Predicate
s与Java8一起使用可以构建一些非常流畅的API,例如添加您自己类型的功能性Predicate
:
@FunctionalInterface
public interface ComposablePredicate extends Predicate, java.util.function.Predicate<Exchange> {
@Override
default boolean matches(Exchange exchange) {
return test(exchange);
}
@Override
default ComposablePredicate and(java.util.function.Predicate<? super Exchange> other) {
Objects.requireNonNull(other);
return (t) -> test(t) && other.test(t);
}
@Override
default ComposablePredicate negate() {
return (t) -> !test(t);
}
@Override
default ComposablePredicate or(java.util.function.Predicate<? super Exchange> other) {
Objects.requireNonNull(other);
return (t) -> test(t) || other.test(t);
}
}
它允许你写这样的东西:
public void configure() throws Exception {
from( incomingRoute )
.choice()
.when( bodyTypeIs( TYPE.A ) .or ( bodyTypeIs( TYPE.A1 ) ) )
.to( A_Endpoint )
.when( bodyTypeIs( TYPE.B ).negate() )
.to( NOT_B_Endpoint )
.when( bodyTypeIs( TYPE.C ) .and ( bodyNameIs( "name" ) ) )
.to( C_Endpoint )
.otherwise()
.to( errorEndpoint );
}
private ComposablePredicate bodyTypeIs(TYPE type) {
return e -> bodyFrom(e).getType() == type;
}
private BodyType bodyFrom(Exchange e) {
return e.getIn().getBody(BodyType.class);
}
private ComposablePredicate bodyNameIs(String name) {
return e -> bodyFrom(e).getName().equals(name);
}
问题内容: 除了看起来不太好以外,是否有其他替代方法可以在Java中实现切换案例。根据选择必须执行的方法,一组值会组合在一起。 问题答案: 想必您正在努力满足案件不变的要求。通常,这是代码气味,但是您可以做一些事情。您可能想提出并链接到另一个详细说明您为何尝试切换的问题。 在上面的示例中,您可能想要映射到“处理程序”,例如 然后,这一切都变成了查找。 同样,这有点气味,因此请发布一个说明原因的问题
有人能建议我如何替换下面的代码吗? 如何重写代码以避免重复块{code>case 3:{code block A;break;} ? 如何将案例1和案例3的代码组合起来?
MIP Page 最大的工作在于将多个独立的页面融合在一起,让它们拥有像单页应用 (SPA) 那样的切换效果和使用体验,解决“第二跳”的问题。这一部分简单讨论一下它的实现方案。 方案核心主要有以下几点: MIP Page 借助 iframe 实现了页面之间的互相隔离 通过 iframe 和外界的通讯来实现页面之间的通讯和传递数据 为了加载性能考虑,第一个页面维持原状,不放入 iframe 之中。
问题内容: 我需要在JavaScript的switch语句中使用多种情况,例如: 我怎样才能做到这一点?如果没有办法在JavaScript中执行类似的操作,我想知道一个也遵循DRY概念的替代解决方案。 问题答案: 使用语句的直通功能。匹配的大小写将一直运行到找到(或语句的末尾)为止,因此您可以这样写:
问题内容: 使用规则如下: case表达式必须计算为。 case(t)表达式必须与switch(t)具有相同的类型,其中t是类型(字符串)。 如果我运行此代码: 它给出Compile-error为: 另一方面,如果我尝试使用,它可以正常工作。 据我所知, 是对位于堆上的对象的引用。并且它本身是一个编译时常量。 这是否意味着不是编译时间常数? 问题答案: 用这个, 根据文档 基本类型或String类
我正在尝试向异步路由发送消息,但它不起作用。我刚刚在github上创建了一个项目来模拟这个问题