rxjava的observable订阅时在oncomplete被调用时取消订阅
在非android环境中使用rxjava2.x时,如果需要在observable的oncomplete被调用时取消订阅,可以采用以下方法:
在oncomplete中设置completablefuture.complete通知调用方已结束:
table.subscribe(tableins -> { // system.out.println("-------information-------"); system.out.println(tableins); }, throwable -> { throw new schemaexportexception(throwable); }, new action() { @override public void run() throws exception { system.out.println("complete"); // 在这里取消订阅 completablefuture.complete(); } });
调用方可以根据completablefuture来判断observable是否已完成:
long startStamp = System.currentTimeMillis(); // Flowable Flowable<Table> tableFlowable = result.getAll(dbName.get(), strategy).flatMap(new Function<Table, Publisher<Table>>() { @Override public Publisher<Table> apply(@NonNull Table table) throws Exception { return result.getTableColumn(table).flatMap(new Function<List<Column>, SingleSource<Table>>() { @Override public SingleSource<Table> apply(@NonNull List<Column> columns) throws Exception { return Single.just(table.fillColumn(columns)); } }).flatMapPublisher(new Function<Table, Publisher<? extends Table>>() { @Override public Publisher<? extends Table> apply(@NonNull Table table) throws Exception { return Flowable.just(table); } }); } }); Disposable disposable = null; try { disposable = out.flush(info, tableFlowable); CompletableFuture<String> future = out.getFuture(); while (!future.isDone()) { logger.info("[ERE-Flowable]未完成,线程休眠1秒"); Thread.currentThread().sleep(1000, 0); } String result = future.get(); logger.info("[ERE-Flowable]完成, 结果:" + result); if (result.equals("OK")) { long finishStamp = System.currentTimeMillis(); clearHander(disposable, "[ERE-Flowable]RxJava disposed because complete, WithTime: " + (finishStamp - startStamp)); } } catch (Exception e) { clearHander(disposable, "[ERE-Flowable]RxJava disposed has Exception: " + e.getMessage()); }
如何编写和贡献Java框架文档和教程?
为什么 Java 函数在高负载下会出现执行效率降低?
理解Java中的float和double
Finalize() 方法
Java DES加密后,如何用PHP解密?
在配置自定义线程池时,如果没有调用`initialize()`方法,程序仍然可以正常运行的原因可能有以下几种: 1. **自动初始化**:某些线程池实现可能在首次使用时自动进行初始化。在这种情况下,即使你没有显式调用`initialize()`方法,线程池也会在需要时自动初始化。 2. **延迟初始化**:有些线程池设计支持延迟初始化,即在第一次提交任务时才进行初始化。如果你的代码在使用线程池之前没有显式调用`initialize()`方法,但随后提交了任务,那么线程池可能会在提交任务时自动初始化。