0

由于我在我的堆栈中使用 Vertx 3.1,我正在考虑使用这些工具带来的 Future 功能,但在阅读之后,API 似乎对我来说非常有限。我什至找不到让未来等待 Observable 的方法。这是我的代码

          public Observable<CommitToOrderCommand> validateProductRestrictions(CommitToOrderCommand cmd) {
    Future<Observable<CommitToOrderCommand>> future = Future.future();
    orderRepository.getOrder(cmd, cmd.orderId)
                   .flatMap(order -> validateOrderProducts(cmd, order))
                   .subscribe(map -> checkMapValues(map, future, cmd));
     Observable<CommitToOrderCommand> result = future.result();
    if(errorFound){
        throw MAX_QUANTITY_PRODUCT_EXCEED.create("Fail"/*restrictions.getBulkBuyLimit().getDescription())*/);
    }
    return result;
}

private void checkMapValues(Multimap<String, BigDecimal> totalUnitByRestrictions, Future<Observable<CommitToOrderCommand>> future,
                            CommitToOrderCommand cmd) {
    for (String restrictionName : totalUnitByRestrictions.keySet()) {
        Restrictions restrictions = Restrictions.valueOf(restrictionName);
        if (totalUnitByRestrictions.get(restrictionName)
                                   .stream()
                                   .reduce(BigDecimal.ZERO, BigDecimal::add)
                                   .compareTo(restrictions.getBulkBuyLimit()
                                                          .getMaxQuantity()) == 1) {
            errorFound = true;
        }
    }
    future.complete(Observable.just(cmd));
}

在我的第一个 Observable 的 onComplete 中,我正在检查结果,完成之后是我完成未来以解除阻塞操作的时间。但我期待 future.result 不会阻塞,直到 future.complete 像我预期的那样被调用。相反只是返回null。

知道这里有什么问题吗?

问候。

4

1 回答 1

3

vertx 未来不会阻塞,而是使用在注入结果时调用的处理程序(请参阅setHandlerisComplete)。

如果外层代码需要 Observable,则不需要将其包装在 Future 中,只需 return 即可Observable<T>Future<Observable<T>>没有多大意义,你混合了两种做异步结果的方式。

请注意,有一些方法可以将 Observable 折叠成 Future,但困难在于 Observable 可能会发出多个项目,而 Future 只能容纳一个项目。您已经通过将结果收集到单个地图发射中来解决这个问题。

由于Observable这只发出一个项目,如果你想要一个项目,Future你应该subscribe调用它并调用future.complete(yourMap)onNext方法。还要定义一个onError将调用future.fail.

于 2015-12-06T11:19:06.750 回答